Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 Loading... | |
| 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 Loading... | |
| 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 |
| OLD | NEW |