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

Side by Side Diff: gin/v8_platform.cc

Issue 2650943008: [gin] Fire observer after added when recording is in progress. (Closed)
Patch Set: Add tests Created 3 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 unified diff | Download patch
« no previous file with comments | « gin/BUILD.gn ('k') | gin/v8_platform_unittest.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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "gin/public/v8_platform.h" 5 #include "gin/public/v8_platform.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/location.h" 8 #include "base/location.h"
9 #include "base/sys_info.h" 9 #include "base/sys_info.h"
10 #include "base/threading/worker_pool.h" 10 #include "base/threading/worker_pool.h"
(...skipping 199 matching lines...) Expand 10 before | Expand all | Expand 10 after
210 } 210 }
211 211
212 void OnTraceLogDisabled() final { 212 void OnTraceLogDisabled() final {
213 base::AutoLock lock(mutex_); 213 base::AutoLock lock(mutex_);
214 for (auto o : observers_) { 214 for (auto o : observers_) {
215 o->OnTraceDisabled(); 215 o->OnTraceDisabled();
216 } 216 }
217 } 217 }
218 218
219 void AddObserver(v8::Platform::TraceStateObserver* observer) { 219 void AddObserver(v8::Platform::TraceStateObserver* observer) {
220 base::AutoLock lock(mutex_); 220 {
221 DCHECK(!observers_.count(observer)); 221 base::AutoLock lock(mutex_);
222 observers_.insert(observer); 222 DCHECK(!observers_.count(observer));
223 if (observers_.size() == 1) { 223 observers_.insert(observer);
alph 2017/01/25 22:39:06 Can you please move this line past 225. Just to be
lpy 2017/01/25 23:11:15 I don't understand here, what do you mean similar
alph 2017/01/25 23:26:32 My suggestion implied you change "observers_.size(
lpy 2017/01/26 02:26:41 Done.
224 base::trace_event::TraceLog::GetInstance()->AddEnabledStateObserver(this); 224 if (observers_.size() == 1) {
225 base::trace_event::TraceLog::GetInstance()->AddEnabledStateObserver(
226 this);
227 }
225 } 228 }
229 // Fire the observer if recording is already in progress.
230 if (base::trace_event::TraceLog::GetInstance()->IsEnabled())
231 observer->OnTraceEnabled();
226 } 232 }
227 233
228 void RemoveObserver(v8::Platform::TraceStateObserver* observer) { 234 void RemoveObserver(v8::Platform::TraceStateObserver* observer) {
229 base::AutoLock lock(mutex_); 235 base::AutoLock lock(mutex_);
230 DCHECK(observers_.count(observer) == 1); 236 DCHECK(observers_.count(observer) == 1);
231 observers_.erase(observer); 237 observers_.erase(observer);
232 if (observers_.empty()) { 238 if (observers_.empty()) {
233 base::trace_event::TraceLog::GetInstance()->RemoveEnabledStateObserver( 239 base::trace_event::TraceLog::GetInstance()->RemoveEnabledStateObserver(
234 this); 240 this);
235 } 241 }
(...skipping 15 matching lines...) Expand all
251 v8::Platform::TraceStateObserver* observer) { 257 v8::Platform::TraceStateObserver* observer) {
252 g_trace_state_dispatcher.Get().AddObserver(observer); 258 g_trace_state_dispatcher.Get().AddObserver(observer);
253 } 259 }
254 260
255 void V8Platform::RemoveTraceStateObserver( 261 void V8Platform::RemoveTraceStateObserver(
256 v8::Platform::TraceStateObserver* observer) { 262 v8::Platform::TraceStateObserver* observer) {
257 g_trace_state_dispatcher.Get().RemoveObserver(observer); 263 g_trace_state_dispatcher.Get().RemoveObserver(observer);
258 } 264 }
259 265
260 } // namespace gin 266 } // namespace gin
OLDNEW
« no previous file with comments | « gin/BUILD.gn ('k') | gin/v8_platform_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698