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

Side by Side Diff: content/common/socket_stream_dispatcher.cc

Issue 8491043: Allow linker initialization of lazy instance (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: willchan comments + rebase Created 9 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « content/common/np_channel_base.cc ('k') | content/plugin/plugin_thread.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/common/socket_stream_dispatcher.h" 5 #include "content/common/socket_stream_dispatcher.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/id_map.h" 9 #include "base/id_map.h"
10 #include "base/lazy_instance.h" 10 #include "base/lazy_instance.h"
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 static base::LazyInstance< 60 static base::LazyInstance<
61 IDMap<IPCWebSocketStreamHandleBridge>, 61 IDMap<IPCWebSocketStreamHandleBridge>,
62 base::LeakyLazyInstanceTraits<IDMap<IPCWebSocketStreamHandleBridge> > > 62 base::LeakyLazyInstanceTraits<IDMap<IPCWebSocketStreamHandleBridge> > >
63 all_bridges; 63 all_bridges;
64 }; 64 };
65 65
66 // static 66 // static
67 base::LazyInstance< 67 base::LazyInstance<
68 IDMap<IPCWebSocketStreamHandleBridge>, 68 IDMap<IPCWebSocketStreamHandleBridge>,
69 base::LeakyLazyInstanceTraits<IDMap<IPCWebSocketStreamHandleBridge> > > 69 base::LeakyLazyInstanceTraits<IDMap<IPCWebSocketStreamHandleBridge> > >
70 IPCWebSocketStreamHandleBridge::all_bridges(base::LINKER_INITIALIZED); 70 IPCWebSocketStreamHandleBridge::all_bridges = LAZY_INSTANCE_INITIALIZER;
71 71
72 /* static */ 72 /* static */
73 IPCWebSocketStreamHandleBridge* IPCWebSocketStreamHandleBridge::FromSocketId( 73 IPCWebSocketStreamHandleBridge* IPCWebSocketStreamHandleBridge::FromSocketId(
74 int id) { 74 int id) {
75 return all_bridges.Get().Lookup(id); 75 return all_bridges.Get().Lookup(id);
76 } 76 }
77 77
78 IPCWebSocketStreamHandleBridge::~IPCWebSocketStreamHandleBridge() { 78 IPCWebSocketStreamHandleBridge::~IPCWebSocketStreamHandleBridge() {
79 DVLOG(1) << "IPCWebSocketStreamHandleBridge destructor socket_id=" 79 DVLOG(1) << "IPCWebSocketStreamHandleBridge destructor socket_id="
80 << socket_id_; 80 << socket_id_;
(...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after
222 } 222 }
223 223
224 void SocketStreamDispatcher::OnClosed(int socket_id) { 224 void SocketStreamDispatcher::OnClosed(int socket_id) {
225 IPCWebSocketStreamHandleBridge* bridge = 225 IPCWebSocketStreamHandleBridge* bridge =
226 IPCWebSocketStreamHandleBridge::FromSocketId(socket_id); 226 IPCWebSocketStreamHandleBridge::FromSocketId(socket_id);
227 if (bridge) 227 if (bridge)
228 bridge->OnClosed(); 228 bridge->OnClosed();
229 else 229 else
230 DLOG(ERROR) << "No SocketStreamHandleBridge for socket_id=" << socket_id; 230 DLOG(ERROR) << "No SocketStreamHandleBridge for socket_id=" << socket_id;
231 } 231 }
OLDNEW
« no previous file with comments | « content/common/np_channel_base.cc ('k') | content/plugin/plugin_thread.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698