Chromium Code Reviews| Index: bench/SkipZeroesBench.cpp |
| diff --git a/bench/ImageDecodeBench.cpp b/bench/SkipZeroesBench.cpp |
| similarity index 58% |
| copy from bench/ImageDecodeBench.cpp |
| copy to bench/SkipZeroesBench.cpp |
| index 3a61163862082830bfcbcc7b3d5f8d421ff9b335..ca6b371b825578a67bd6e680a73569a98201d546 100644 |
| --- a/bench/ImageDecodeBench.cpp |
| +++ b/bench/SkipZeroesBench.cpp |
| @@ -18,24 +18,35 @@ __SK_FORCE_IMAGE_DECODER_LINKING; |
| class SkCanvas; |
| -class ImageDecodeBench : public SkBenchmark { |
| +class SkipZeroesBench : public SkBenchmark { |
| public: |
| - ImageDecodeBench(void* p, const char* filename) |
| - : fName("image_decode_") |
| + SkipZeroesBench(const char* filename, bool skipZeroes) |
| + : fName("SkipZeroes_") |
| + , fDecoder(NULL) |
| , fFilename(filename) |
| , fStream() |
| + , fSkipZeroes(skipZeroes) |
| , fValid(false) { |
| - fName.append(SkOSPath::SkBasename(filename)); |
| + fName.append(filename); |
| + if (skipZeroes) { |
| + fName.append("_skip_zeroes"); |
| + } else { |
| + fName.append("_write_zeroes"); |
| + } |
| fIsRendering = false; |
| } |
| + ~SkipZeroesBench() { |
| + SkDELETE(fDecoder); |
| + } |
| protected: |
| virtual const char* onGetName() SK_OVERRIDE { |
| return fName.c_str(); |
| } |
| virtual void onPreDraw() SK_OVERRIDE { |
| - SkFILEStream fileStream(fFilename.c_str()); |
| + SkString fullPath = SkOSPath::SkPathJoin(GetResourcePath().c_str(), fFilename.c_str()); |
| + SkFILEStream fileStream(fullPath.c_str()); |
| fValid = fileStream.isValid() && fileStream.getLength() > 0; |
| if (fValid) { |
| const size_t size = fileStream.getLength(); |
| @@ -45,6 +56,14 @@ protected: |
| } else { |
| SkAutoTUnref<SkData> skdata(SkData::NewFromMalloc(data, size)); |
| fStream.setData(skdata.get()); |
| + fDecoder = SkImageDecoder::Factory(&fStream); |
| + if (fDecoder) { |
| + // Disabling until the feature is checked in. |
| + // See https://codereview.chromium.org/24269006/ |
| + //fDecoder->setSkipWritingZeroes(fSkipZeroes); |
| + } else { |
| + fValid = false; |
| + } |
| } |
| } |
| } |
| @@ -59,7 +78,8 @@ protected: |
| // Decode a bunch of times |
| SkBitmap bm; |
| for (int i = 0; i < this->getLoops(); ++i) { |
| - SkDEBUGCODE(bool success =) SkImageDecoder::DecodeStream(&fStream, &bm); |
| + SkDEBUGCODE(bool success =) fDecoder->decode(&fStream, &bm, |
| + SkImageDecoder::kDecodePixels_Mode); |
| #ifdef SK_DEBUG |
| if (!success) { |
| SkDebugf("failed to decode %s\n", fName.c_str()); |
| @@ -78,13 +98,15 @@ protected: |
| private: |
| SkString fName; |
| + SkImageDecoder* fDecoder; |
|
mtklein
2013/09/25 13:48:32
SkAutoTDelete?
scroggo
2013/09/25 17:54:57
Done.
|
| const SkString fFilename; |
| SkMemoryStream fStream; |
| + bool fSkipZeroes; |
| bool fValid; |
| typedef SkBenchmark INHERITED; |
| }; |
| -// These are files which call decodePalette |
| -//DEF_BENCH( return SkNEW_ARGS(ImageDecodeBench, ("/usr/local/google/home/scroggo/Downloads/images/hal_163x90.png")); ) |
| -//DEF_BENCH( return SkNEW_ARGS(ImageDecodeBench, ("/usr/local/google/home/scroggo/Downloads/images/box_19_top-left.png")); ) |
| +// Enable the true version once the feature is checked in. |
| +//DEF_BENCH( return SkNEW_ARGS(SkipZeroesBench, ("arrow.png", true))); |
| +DEF_BENCH( return SkNEW_ARGS(SkipZeroesBench, ("arrow.png", false))); |