// 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(this), start_time_); } void AutoOpenCloseEvent::End() { DCHECK(thread_checker_.CalledOnValidThread()); TRACE_EVENT_ASYNC_END0(category_, event_name_, static_cast(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(this), start_time_); } void AutoOpenCloseEvent::OnTraceLogDisabled() {} } // namespace trace_event } // namespace base