diff options
author | Angelo Mantellini <angelo.mantellini@cisco.com> | 2020-06-03 14:47:16 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@fd.io> | 2020-06-03 14:47:16 +0000 |
commit | f3f4f8cf18bf21c522e73571d183c95ef5dcb33c (patch) | |
tree | 0eb89fe5ed20ea42985f49a3f0d40f32db25ae0f /apps/http-proxy/src/forwarder_interface.cc | |
parent | 8340427544b3adedd57736fb13ca69c5549b6fc1 (diff) | |
parent | 5d8156ea4c34f9a3cb986da16a71faebfb2add6b (diff) |
Merge "[HICN-622] Add stop() functionality to http proxy."
Diffstat (limited to 'apps/http-proxy/src/forwarder_interface.cc')
-rw-r--r-- | apps/http-proxy/src/forwarder_interface.cc | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/apps/http-proxy/src/forwarder_interface.cc b/apps/http-proxy/src/forwarder_interface.cc index 105d5a8e9..d80939b8b 100644 --- a/apps/http-proxy/src/forwarder_interface.cc +++ b/apps/http-proxy/src/forwarder_interface.cc @@ -13,7 +13,7 @@ * limitations under the License. */ -#include "forwarder_interface.h" +#include <hicn/http-proxy/forwarder_interface.h> #include <arpa/inet.h> #include <hicn/transport/utils/log.h> @@ -41,16 +41,18 @@ int ForwarderInterface::connectToForwarder() { } void ForwarderInterface::close() { - internal_ioservice_.post([this]() { - work_.reset(); - if (sock_) { - hc_sock_free(sock_); - sock_ = nullptr; - } - }); + if (!closed_) { + internal_ioservice_.post([this]() { + work_.reset(); + if (sock_) { + hc_sock_free(sock_); + sock_ = nullptr; + } + }); - if (thread_->joinable()) { - thread_->join(); + if (thread_->joinable()) { + thread_->join(); + } } } |