1 2 /* 3 * Copyright 2014 Google Inc. 4 * 5 * Use of this source code is governed by a BSD-style license that can be 6 * found in the LICENSE file. 7 */ 8 9 #include "GrTraceMarker.h" 10 #include "GrTracing.h" 11 #include "SkString.h" 12 #include "SkTSort.h" 13 14 //////////////////////////////////////////////////////////////////////////////// 15 16 //////////////////////////////////////////////////////////////////////////////// 17 18 GrTraceMarkerSet::GrTraceMarkerSet(const GrTraceMarkerSet& other) { 19 this->addSet(other); 20 } 21 22 void GrTraceMarkerSet::add(const GrGpuTraceMarker& marker) { 23 this->fMarkerArray.push(marker); 24 } 25 26 void GrTraceMarkerSet::addSet(const GrTraceMarkerSet& markerSet) { 27 for (Iter iter = markerSet.begin(); iter != markerSet.end(); ++iter) { 28 this->add(*iter); 29 } 30 } 31 32 void GrTraceMarkerSet::remove(const GrGpuTraceMarker& marker) { 33 SkASSERT(-1 != fMarkerArray.find(marker)); 34 int index = this->fMarkerArray.find(marker); 35 this->fMarkerArray.remove(index); 36 } 37 38 int GrTraceMarkerSet::count() const { 39 return this->fMarkerArray.count(); 40 } 41 42 SkString GrTraceMarkerSet::toStringLast() const { 43 const int numMarkers = this->fMarkerArray.count(); 44 SkString marker_string; 45 if (numMarkers > 0) { 46 GrGpuTraceMarker& lastMarker = this->fMarkerArray[numMarkers - 1]; 47 marker_string.append(lastMarker.fMarker); 48 if (lastMarker.fID != -1) { 49 marker_string.append("("); 50 marker_string.appendS32(lastMarker.fID); 51 marker_string.append(")"); 52 } 53 } 54 return marker_string; 55 } 56 57 SkString GrTraceMarkerSet::toString() const { 58 SkTQSort<GrGpuTraceMarker>(this->fMarkerArray.begin(), this->fMarkerArray.end() - 1); 59 SkString marker_string; 60 const char* prevMarkerName = ""; 61 int prevMarkerID = -1; 62 int counter = 0; 63 const int numMarkers = this->fMarkerArray.count(); 64 65 // check used for GrGpuGL device after we've already collapsed all markers 66 if (1 == numMarkers && -1 == this->fMarkerArray[0].fID) { 67 marker_string.append(this->fMarkerArray[0].fMarker); 68 return marker_string; 69 } 70 71 for (int i = 0; i < numMarkers; ++i ) { 72 GrGpuTraceMarker& currMarker = this->fMarkerArray[i]; 73 const char* currCmd = currMarker.fMarker; 74 if (currCmd != prevMarkerName) { 75 if (prevMarkerID != -1) { 76 marker_string.append(") "); 77 } 78 marker_string.append(currCmd); 79 if (currMarker.fID != -1) { 80 marker_string.append("("); 81 marker_string.appendS32(currMarker.fID); 82 } 83 prevMarkerName = currCmd; 84 } else if (currMarker.fID != prevMarkerID) { 85 marker_string.append(", "); 86 marker_string.appendS32(currMarker.fID); 87 } 88 prevMarkerID = currMarker.fID; 89 ++counter; 90 } 91 if (counter > 0 && prevMarkerID != -1) { 92 marker_string.append(")"); 93 } 94 return marker_string; 95 } 96 97 GrTraceMarkerSet::Iter GrTraceMarkerSet::begin() const { 98 return Iter(this, 0); 99 } 100 101 GrTraceMarkerSet::Iter GrTraceMarkerSet::end() const { 102 return Iter(this, this->fMarkerArray.count()); 103 } 104 105