Skip to content

Commit

Permalink
Plumb TraceLogStateObserver into v8.
Browse files Browse the repository at this point in the history
BUG=406277

Review-Url: https://codereview.chromium.org/2349563002
Cr-Commit-Position: refs/heads/master@{#419903}
  • Loading branch information
a1ph authored and Commit bot committed Sep 21, 2016
1 parent 2236ce0 commit 290f630
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 0 deletions.
3 changes: 3 additions & 0 deletions gin/public/v8_platform.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,9 @@ class GIN_EXPORT V8Platform : public NON_EXPORTED_BASE(v8::Platform) {
const char* name,
uint64_t handle) override;

void AddTraceStateObserver(v8::Platform::TraceStateObserver*) override;
void RemoveTraceStateObserver(v8::Platform::TraceStateObserver*) override;

private:
friend struct base::DefaultLazyInstanceTraits<V8Platform>;

Expand Down
62 changes: 62 additions & 0 deletions gin/v8_platform.cc
Original file line number Diff line number Diff line change
Expand Up @@ -116,4 +116,66 @@ void V8Platform::UpdateTraceEventDuration(const uint8_t* category_enabled_flag,
traceEventHandle);
}

namespace {

class EnabledStateObserverImpl final
: public base::trace_event::TraceLog::EnabledStateObserver {
public:
EnabledStateObserverImpl() = default;

void OnTraceLogEnabled() final {
base::AutoLock lock(mutex_);
for (auto o : observers_) {
o->OnTraceEnabled();
}
}

void OnTraceLogDisabled() final {
base::AutoLock lock(mutex_);
for (auto o : observers_) {
o->OnTraceDisabled();
}
}

void AddObserver(v8::Platform::TraceStateObserver* observer) {
base::AutoLock lock(mutex_);
DCHECK(!observers_.count(observer));
observers_.insert(observer);
if (observers_.size() == 1) {
base::trace_event::TraceLog::GetInstance()->AddEnabledStateObserver(this);
}
}

void RemoveObserver(v8::Platform::TraceStateObserver* observer) {
base::AutoLock lock(mutex_);
DCHECK(observers_.count(observer) == 1);
observers_.erase(observer);
if (observers_.empty()) {
base::trace_event::TraceLog::GetInstance()->RemoveEnabledStateObserver(
this);
}
}

private:
base::Lock mutex_;
std::unordered_set<v8::Platform::TraceStateObserver*> observers_;

DISALLOW_COPY_AND_ASSIGN(EnabledStateObserverImpl);
};

base::LazyInstance<EnabledStateObserverImpl>::Leaky g_trace_state_dispatcher =
LAZY_INSTANCE_INITIALIZER;

} // namespace

void V8Platform::AddTraceStateObserver(
v8::Platform::TraceStateObserver* observer) {
g_trace_state_dispatcher.Get().AddObserver(observer);
}

void V8Platform::RemoveTraceStateObserver(
v8::Platform::TraceStateObserver* observer) {
g_trace_state_dispatcher.Get().RemoveObserver(observer);
}

} // namespace gin

0 comments on commit 290f630

Please sign in to comment.