Thrift CPP threading fixes
Reviewed By: karl
git-svn-id: https://svn.apache.org/repos/asf/incubator/thrift/trunk@665045 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/lib/cpp/configure.ac b/lib/cpp/configure.ac
index 1f2763c..878e55a 100644
--- a/lib/cpp/configure.ac
+++ b/lib/cpp/configure.ac
@@ -28,6 +28,12 @@
AC_CHECK_FUNCS([strtoul])
+AC_CHECK_FUNCS([memmove])
+
+AC_CHECK_FUNCS([strstr])
+
+AC_CHECK_FUNCS([strchr])
+
AC_CHECK_HEADERS([arpa/inet.h])
AC_CHECK_HEADERS([fcntl.h])
@@ -100,8 +106,4 @@
AC_PROG_LIBTOOL
-CFLAGS="-g -O2"
-
-CXXFLAGS="-g -O2"
-
AC_OUTPUT(Makefile)
diff --git a/lib/cpp/src/server/TSimpleServer.cpp b/lib/cpp/src/server/TSimpleServer.cpp
index e7d7e9b..40d7ed9 100644
--- a/lib/cpp/src/server/TSimpleServer.cpp
+++ b/lib/cpp/src/server/TSimpleServer.cpp
@@ -57,21 +57,21 @@
outputTransport->close();
client->close();
} catch (TTransportException& ttx) {
- if (inputTransport.get() != NULL) { inputTransport->close(); }
- if (outputTransport.get() != NULL) { outputTransport->close(); }
- if (client.get() != NULL) { client->close(); }
+ if (inputTransport != NULL) { inputTransport->close(); }
+ if (outputTransport != NULL) { outputTransport->close(); }
+ if (client != NULL) { client->close(); }
cerr << "TServerTransport died on accept: " << ttx.what() << endl;
continue;
} catch (TException& tx) {
- if (inputTransport.get() != NULL) { inputTransport->close(); }
- if (outputTransport.get() != NULL) { outputTransport->close(); }
- if (client.get() != NULL) { client->close(); }
+ if (inputTransport != NULL) { inputTransport->close(); }
+ if (outputTransport != NULL) { outputTransport->close(); }
+ if (client != NULL) { client->close(); }
cerr << "Some kind of accept exception: " << tx.what() << endl;
continue;
} catch (string s) {
- if (inputTransport.get() != NULL) { inputTransport->close(); }
- if (outputTransport.get() != NULL) { outputTransport->close(); }
- if (client.get() != NULL) { client->close(); }
+ if (inputTransport != NULL) { inputTransport->close(); }
+ if (outputTransport != NULL) { outputTransport->close(); }
+ if (client != NULL) { client->close(); }
cerr << "TThreadPoolServer: Unknown exception: " << s << endl;
break;
}
diff --git a/lib/cpp/src/server/TThreadPoolServer.cpp b/lib/cpp/src/server/TThreadPoolServer.cpp
index dcbf2f2..2542de9 100644
--- a/lib/cpp/src/server/TThreadPoolServer.cpp
+++ b/lib/cpp/src/server/TThreadPoolServer.cpp
@@ -42,7 +42,7 @@
} catch (TTransportException& ttx) {
// This is reasonably expected, client didn't send a full request so just
// ignore him
- //cerr << "TThreadPoolServer client died: " << ttx.what() << endl;
+ cerr << "TThreadPoolServer client died: " << ttx.what() << endl;
} catch (TException& x) {
cerr << "TThreadPoolServer exception: " << x.what() << endl;
} catch (...) {
@@ -100,6 +100,12 @@
while (!stop_) {
try {
+ client.reset();
+ inputTransport.reset();
+ outputTransport.reset();
+ inputProtocol.reset();
+ outputProtocol.reset();
+
// Fetch client from server
client = serverTransport_->accept();
@@ -113,23 +119,23 @@
threadManager_->add(shared_ptr<TThreadPoolServer::Task>(new TThreadPoolServer::Task(processor_, inputProtocol, outputProtocol)));
} catch (TTransportException& ttx) {
- if (inputTransport.get() != NULL) { inputTransport->close(); }
- if (outputTransport.get() != NULL) { outputTransport->close(); }
- if (client.get() != NULL) { client->close(); }
+ if (inputTransport != NULL) { inputTransport->close(); }
+ if (outputTransport != NULL) { outputTransport->close(); }
+ if (client != NULL) { client->close(); }
if (!stop_ || ttx.getType() != TTransportException::INTERRUPTED) {
cerr << "TThreadPoolServer: TServerTransport died on accept: " << ttx.what() << endl;
}
continue;
} catch (TException& tx) {
- if (inputTransport.get() != NULL) { inputTransport->close(); }
- if (outputTransport.get() != NULL) { outputTransport->close(); }
- if (client.get() != NULL) { client->close(); }
+ if (inputTransport != NULL) { inputTransport->close(); }
+ if (outputTransport != NULL) { outputTransport->close(); }
+ if (client != NULL) { client->close(); }
cerr << "TThreadPoolServer: Caught TException: " << tx.what() << endl;
continue;
} catch (string s) {
- if (inputTransport.get() != NULL) { inputTransport->close(); }
- if (outputTransport.get() != NULL) { outputTransport->close(); }
- if (client.get() != NULL) { client->close(); }
+ if (inputTransport != NULL) { inputTransport->close(); }
+ if (outputTransport != NULL) { outputTransport->close(); }
+ if (client != NULL) { client->close(); }
cerr << "TThreadPoolServer: Unknown exception: " << s << endl;
break;
}