/* * Copyright 2014 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #include "GrTraceMarker.h" #include "GrTracing.h" #include "SkString.h" #include "SkTSort.h" //////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////// GrTraceMarkerSet::GrTraceMarkerSet(const GrTraceMarkerSet& other) { this->addSet(other); } void GrTraceMarkerSet::add(const GrGpuTraceMarker& marker) { this->fMarkerArray.push(marker); } void GrTraceMarkerSet::addSet(const GrTraceMarkerSet& markerSet) { for (Iter iter = markerSet.begin(); iter != markerSet.end(); ++iter) { this->add(*iter); } } void GrTraceMarkerSet::remove(const GrGpuTraceMarker& marker) { SkASSERT(-1 != fMarkerArray.find(marker)); int index = this->fMarkerArray.find(marker); this->fMarkerArray.remove(index); } int GrTraceMarkerSet::count() const { return this->fMarkerArray.count(); } SkString GrTraceMarkerSet::toStringLast() const { const int numMarkers = this->fMarkerArray.count(); SkString marker_string; if (numMarkers > 0) { GrGpuTraceMarker& lastMarker = this->fMarkerArray[numMarkers - 1]; marker_string.append(lastMarker.fMarker); if (lastMarker.fID != -1) { marker_string.append("("); marker_string.appendS32(lastMarker.fID); marker_string.append(")"); } } return marker_string; } SkString GrTraceMarkerSet::toString() const { SkTQSort<GrGpuTraceMarker>(this->fMarkerArray.begin(), this->fMarkerArray.end() - 1); SkString marker_string; const char* prevMarkerName = ""; int prevMarkerID = -1; int counter = 0; const int numMarkers = this->fMarkerArray.count(); // check used for GrGLGpu device after we've already collapsed all markers if (1 == numMarkers && -1 == this->fMarkerArray[0].fID) { marker_string.append(this->fMarkerArray[0].fMarker); return marker_string; } for (int i = 0; i < numMarkers; ++i ) { GrGpuTraceMarker& currMarker = this->fMarkerArray[i]; const char* currCmd = currMarker.fMarker; if (currCmd != prevMarkerName) { if (prevMarkerID != -1) { marker_string.append(") "); } marker_string.append(currCmd); if (currMarker.fID != -1) { marker_string.append("("); marker_string.appendS32(currMarker.fID); } prevMarkerName = currCmd; } else if (currMarker.fID != prevMarkerID) { marker_string.append(", "); marker_string.appendS32(currMarker.fID); } prevMarkerID = currMarker.fID; ++counter; } if (counter > 0 && prevMarkerID != -1) { marker_string.append(")"); } return marker_string; } GrTraceMarkerSet::Iter GrTraceMarkerSet::begin() const { return Iter(this, 0); } GrTraceMarkerSet::Iter GrTraceMarkerSet::end() const { return Iter(this, this->fMarkerArray.count()); }