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