| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "SkCommandLineFlags.h" | 8 #include "SkCommandLineFlags.h" |
| 9 #include "SkForceLinking.h" | 9 #include "SkForceLinking.h" |
| 10 #include "SkGraphics.h" | 10 #include "SkGraphics.h" |
| (...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 70 | 70 |
| 71 static void bench_record(SkPicture* src, const char* name, PictureFactory pictur
eFactory) { | 71 static void bench_record(SkPicture* src, const char* name, PictureFactory pictur
eFactory) { |
| 72 const SkMSec start = SkTime::GetMSecs(); | 72 const SkMSec start = SkTime::GetMSecs(); |
| 73 const int width = src ? src->width() : FLAGS_nullSize; | 73 const int width = src ? src->width() : FLAGS_nullSize; |
| 74 const int height = src ? src->height() : FLAGS_nullSize; | 74 const int height = src ? src->height() : FLAGS_nullSize; |
| 75 | 75 |
| 76 for (int i = 0; i < FLAGS_loops; i++) { | 76 for (int i = 0; i < FLAGS_loops; i++) { |
| 77 int recordingFlags = FLAGS_flags; | 77 int recordingFlags = FLAGS_flags; |
| 78 SkAutoTUnref<SkPicture> dst(pictureFactory(width, height, &recordingFlag
s)); | 78 SkAutoTUnref<SkPicture> dst(pictureFactory(width, height, &recordingFlag
s)); |
| 79 SkCanvas* canvas = dst->beginRecording(width, height, recordingFlags); | 79 SkCanvas* canvas = dst->beginRecording(width, height, recordingFlags); |
| 80 if (src) src->draw(canvas); | 80 if (NULL != src) { |
| 81 if (FLAGS_endRecording) dst->endRecording(); | 81 src->draw(canvas); |
| 82 } |
| 83 if (FLAGS_endRecording) { |
| 84 dst->endRecording(); |
| 85 } |
| 82 } | 86 } |
| 83 | 87 |
| 84 const SkMSec elapsed = SkTime::GetMSecs() - start; | 88 const SkMSec elapsed = SkTime::GetMSecs() - start; |
| 85 const double msPerLoop = elapsed / (double)FLAGS_loops; | 89 const double msPerLoop = elapsed / (double)FLAGS_loops; |
| 86 printf("%.2g\t%s\n", msPerLoop, name); | 90 printf("%.2g\t%s\n", msPerLoop, name); |
| 87 } | 91 } |
| 88 | 92 |
| 89 int tool_main(int argc, char** argv); | 93 int tool_main(int argc, char** argv); |
| 90 int tool_main(int argc, char** argv) { | 94 int tool_main(int argc, char** argv) { |
| 91 SkCommandLineFlags::Parse(argc, argv); | 95 SkCommandLineFlags::Parse(argc, argv); |
| 92 SkAutoGraphics autoGraphics; | 96 SkAutoGraphics autoGraphics; |
| 93 | 97 |
| 94 PictureFactory pictureFactory = parse_FLAGS_bbh(); | 98 PictureFactory pictureFactory = parse_FLAGS_bbh(); |
| 95 if (pictureFactory == NULL) { | 99 if (pictureFactory == NULL) { |
| 96 return 1; | 100 return 1; |
| 97 } | 101 } |
| 98 bench_record(NULL, "NULL", pictureFactory); | 102 bench_record(NULL, "NULL", pictureFactory); |
| 99 if (FLAGS_skps.isEmpty()) return 0; | 103 if (FLAGS_skps.isEmpty()) { |
| 104 return 0; |
| 105 } |
| 100 | 106 |
| 101 SkOSFile::Iter it(FLAGS_skps[0], ".skp"); | 107 SkOSFile::Iter it(FLAGS_skps[0], ".skp"); |
| 102 SkString filename; | 108 SkString filename; |
| 103 bool failed = false; | 109 bool failed = false; |
| 104 while (it.next(&filename)) { | 110 while (it.next(&filename)) { |
| 105 const SkString path = SkOSPath::SkPathJoin(FLAGS_skps[0], filename.c_str
()); | 111 const SkString path = SkOSPath::SkPathJoin(FLAGS_skps[0], filename.c_str
()); |
| 106 | 112 |
| 107 SkAutoTUnref<SkStream> stream(SkStream::NewFromFile(path.c_str())); | 113 SkAutoTUnref<SkStream> stream(SkStream::NewFromFile(path.c_str())); |
| 108 if (!stream) { | 114 if (!stream) { |
| 109 SkDebugf("Could not read %s.\n", path.c_str()); | 115 SkDebugf("Could not read %s.\n", path.c_str()); |
| 110 failed = true; | 116 failed = true; |
| 111 continue; | 117 continue; |
| 112 } | 118 } |
| 113 SkAutoTUnref<SkPicture> src(SkPicture::CreateFromStream(stream)); | 119 SkAutoTUnref<SkPicture> src(SkPicture::CreateFromStream(stream)); |
| 114 if (!src) { | 120 if (!src) { |
| 115 SkDebugf("Could not read %s as an SkPicture.\n", path.c_str()); | 121 SkDebugf("Could not read %s as an SkPicture.\n", path.c_str()); |
| 116 failed = true; | 122 failed = true; |
| 117 continue; | 123 continue; |
| 118 } | 124 } |
| 119 bench_record(src, filename.c_str(), pictureFactory); | 125 bench_record(src, filename.c_str(), pictureFactory); |
| 120 } | 126 } |
| 121 return failed ? 1 : 0; | 127 return failed ? 1 : 0; |
| 122 } | 128 } |
| 123 | 129 |
| 124 #if !defined SK_BUILD_FOR_IOS | 130 #if !defined SK_BUILD_FOR_IOS |
| 125 int main(int argc, char * const argv[]) { | 131 int main(int argc, char * const argv[]) { |
| 126 return tool_main(argc, (char**) argv); | 132 return tool_main(argc, (char**) argv); |
| 127 } | 133 } |
| 128 #endif | 134 #endif |
| OLD | NEW |