Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(275)

Unified Diff: remoting/protocol/libjingle_transport_factory.cc

Issue 9433027: Delete Session and SessionManager object synchronously. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: - Created 8 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « remoting/protocol/fake_authenticator.cc ('k') | remoting/protocol/pepper_session_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: remoting/protocol/libjingle_transport_factory.cc
diff --git a/remoting/protocol/libjingle_transport_factory.cc b/remoting/protocol/libjingle_transport_factory.cc
index c2665da3daac9d03fd2a444622dc737b6b3f03a6..3dbedf742cef9ad5797b3c5e82db51f1b1194f8e 100644
--- a/remoting/protocol/libjingle_transport_factory.cc
+++ b/remoting/protocol/libjingle_transport_factory.cc
@@ -4,6 +4,7 @@
#include "remoting/protocol/libjingle_transport_factory.h"
+#include "base/message_loop_proxy.h"
#include "jingle/glue/channel_socket_adapter.h"
#include "jingle/glue/pseudotcp_adapter.h"
#include "jingle/glue/utils.h"
@@ -97,6 +98,15 @@ LibjingleStreamTransport::~LibjingleStreamTransport() {
event_handler_->OnTransportDeleted(this);
// Channel should be already destroyed if we were connected.
DCHECK(!is_connected() || socket_.get() == NULL);
+
+ if (channel_.get()) {
+ base::MessageLoopProxy::current()->DeleteSoon(
+ FROM_HERE, channel_.release());
+ }
+ if (port_allocator_.get()) {
+ base::MessageLoopProxy::current()->DeleteSoon(
+ FROM_HERE, port_allocator_.release());
+ }
}
void LibjingleStreamTransport::Initialize(
@@ -160,6 +170,7 @@ void LibjingleStreamTransport::Connect(
// Create net::Socket adapter for the P2PTransportChannel.
scoped_ptr<jingle_glue::TransportChannelSocketAdapter> channel_adapter(
new jingle_glue::TransportChannelSocketAdapter(channel_.get()));
+
channel_adapter->SetOnDestroyedCallback(base::Bind(
&LibjingleStreamTransport::OnChannelDestroyed, base::Unretained(this)));
@@ -273,13 +284,27 @@ void LibjingleStreamTransport::OnChannelDestroyed() {
void LibjingleStreamTransport::NotifyConnected(
scoped_ptr<net::StreamSocket> socket) {
DCHECK(!is_connected());
- callback_.Run(socket.Pass());
+ StreamTransport::ConnectedCallback callback = callback_;
callback_.Reset();
+ callback.Run(socket.Pass());
}
void LibjingleStreamTransport::NotifyConnectFailed() {
+ DCHECK(!is_connected());
+
socket_.reset();
- channel_.reset();
+
+ // This method may be called in response to a libjingle signal, so
+ // libjingle objects must be deleted asynchronously.
+ if (channel_.get()) {
+ base::MessageLoopProxy::current()->DeleteSoon(
+ FROM_HERE, channel_.release());
+ }
+ if (port_allocator_.get()) {
+ base::MessageLoopProxy::current()->DeleteSoon(
+ FROM_HERE, port_allocator_.release());
+ }
+
authenticator_.reset();
NotifyConnected(scoped_ptr<net::StreamSocket>(NULL));
@@ -294,6 +319,12 @@ LibjingleTransportFactory::LibjingleTransportFactory()
}
LibjingleTransportFactory::~LibjingleTransportFactory() {
+ // This method may be called in response to a libjingle signal, so
+ // libjingle objects must be deleted asynchronously.
+ base::MessageLoopProxy::current()->DeleteSoon(
+ FROM_HERE, socket_factory_.release());
+ base::MessageLoopProxy::current()->DeleteSoon(
+ FROM_HERE, network_manager_.release());
}
scoped_ptr<StreamTransport> LibjingleTransportFactory::CreateStreamTransport() {
« no previous file with comments | « remoting/protocol/fake_authenticator.cc ('k') | remoting/protocol/pepper_session_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698