mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-11-24 14:26:09 +03:00
53 lines
1.6 KiB
C++
53 lines
1.6 KiB
C++
|
// Copyright 2016 The Chromium Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style license that can be
|
||
|
// found in the LICENSE file.
|
||
|
|
||
|
#include "base/trace_event/auto_open_close_event.h"
|
||
|
|
||
|
#include "base/macros.h"
|
||
|
#include "base/time/time.h"
|
||
|
#include "base/trace_event/trace_event.h"
|
||
|
|
||
|
namespace base {
|
||
|
namespace trace_event {
|
||
|
|
||
|
AutoOpenCloseEvent::AutoOpenCloseEvent(AutoOpenCloseEvent::Type type,
|
||
|
const char* category, const char* event_name):
|
||
|
category_(category),
|
||
|
event_name_(event_name),
|
||
|
weak_factory_(this) {
|
||
|
base::trace_event::TraceLog::GetInstance()->AddAsyncEnabledStateObserver(
|
||
|
weak_factory_.GetWeakPtr());
|
||
|
}
|
||
|
|
||
|
AutoOpenCloseEvent::~AutoOpenCloseEvent() {
|
||
|
DCHECK(thread_checker_.CalledOnValidThread());
|
||
|
base::trace_event::TraceLog::GetInstance()->RemoveAsyncEnabledStateObserver(
|
||
|
this);
|
||
|
}
|
||
|
|
||
|
void AutoOpenCloseEvent::Begin() {
|
||
|
DCHECK(thread_checker_.CalledOnValidThread());
|
||
|
start_time_ = TRACE_TIME_TICKS_NOW();
|
||
|
TRACE_EVENT_ASYNC_BEGIN_WITH_TIMESTAMP0(
|
||
|
category_, event_name_, static_cast<void*>(this), start_time_);
|
||
|
}
|
||
|
|
||
|
void AutoOpenCloseEvent::End() {
|
||
|
DCHECK(thread_checker_.CalledOnValidThread());
|
||
|
TRACE_EVENT_ASYNC_END0(category_, event_name_, static_cast<void*>(this));
|
||
|
start_time_ = base::TimeTicks();
|
||
|
}
|
||
|
|
||
|
void AutoOpenCloseEvent::OnTraceLogEnabled() {
|
||
|
DCHECK(thread_checker_.CalledOnValidThread());
|
||
|
if (start_time_.ToInternalValue() != 0)
|
||
|
TRACE_EVENT_ASYNC_BEGIN_WITH_TIMESTAMP0(
|
||
|
category_, event_name_, static_cast<void*>(this), start_time_);
|
||
|
}
|
||
|
|
||
|
void AutoOpenCloseEvent::OnTraceLogDisabled() {}
|
||
|
|
||
|
} // namespace trace_event
|
||
|
} // namespace base
|