1cb93a386Sopenharmony_ci/* 2cb93a386Sopenharmony_ci * Copyright 2017 Google Inc. 3cb93a386Sopenharmony_ci * 4cb93a386Sopenharmony_ci * Use of this source code is governed by a BSD-style license that can be 5cb93a386Sopenharmony_ci * found in the LICENSE file. 6cb93a386Sopenharmony_ci */ 7cb93a386Sopenharmony_ci 8cb93a386Sopenharmony_ci#ifndef SkDebugfTracer_DEFINED 9cb93a386Sopenharmony_ci#define SkDebugfTracer_DEFINED 10cb93a386Sopenharmony_ci 11cb93a386Sopenharmony_ci#include "include/core/SkString.h" 12cb93a386Sopenharmony_ci#include "include/utils/SkEventTracer.h" 13cb93a386Sopenharmony_ci#include "tools/trace/EventTracingPriv.h" 14cb93a386Sopenharmony_ci 15cb93a386Sopenharmony_ci/** 16cb93a386Sopenharmony_ci * A SkEventTracer implementation that logs events using SkDebugf. 17cb93a386Sopenharmony_ci */ 18cb93a386Sopenharmony_ciclass SkDebugfTracer : public SkEventTracer { 19cb93a386Sopenharmony_cipublic: 20cb93a386Sopenharmony_ci SkDebugfTracer() {} 21cb93a386Sopenharmony_ci 22cb93a386Sopenharmony_ci SkEventTracer::Handle addTraceEvent(char phase, 23cb93a386Sopenharmony_ci const uint8_t* categoryEnabledFlag, 24cb93a386Sopenharmony_ci const char* name, 25cb93a386Sopenharmony_ci uint64_t id, 26cb93a386Sopenharmony_ci int numArgs, 27cb93a386Sopenharmony_ci const char** argNames, 28cb93a386Sopenharmony_ci const uint8_t* argTypes, 29cb93a386Sopenharmony_ci const uint64_t* argValues, 30cb93a386Sopenharmony_ci uint8_t flags) override; 31cb93a386Sopenharmony_ci 32cb93a386Sopenharmony_ci void updateTraceEventDuration(const uint8_t* categoryEnabledFlag, 33cb93a386Sopenharmony_ci const char* name, 34cb93a386Sopenharmony_ci SkEventTracer::Handle handle) override; 35cb93a386Sopenharmony_ci 36cb93a386Sopenharmony_ci const uint8_t* getCategoryGroupEnabled(const char* name) override { 37cb93a386Sopenharmony_ci return fCategories.getCategoryGroupEnabled(name); 38cb93a386Sopenharmony_ci } 39cb93a386Sopenharmony_ci 40cb93a386Sopenharmony_ci const char* getCategoryGroupName(const uint8_t* categoryEnabledFlag) override { 41cb93a386Sopenharmony_ci return fCategories.getCategoryGroupName(categoryEnabledFlag); 42cb93a386Sopenharmony_ci } 43cb93a386Sopenharmony_ci 44cb93a386Sopenharmony_ciprivate: 45cb93a386Sopenharmony_ci SkString fIndent; 46cb93a386Sopenharmony_ci int fCnt = 0; 47cb93a386Sopenharmony_ci SkEventTracingCategories fCategories; 48cb93a386Sopenharmony_ci}; 49cb93a386Sopenharmony_ci 50cb93a386Sopenharmony_ci#endif 51