|  | // 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 |