blob: 41a8e8c5f4c7b2226fe696602ac97dcf11581889 [file] [log] [blame]
commit-bot@chromium.org6adce672014-02-03 14:48:17 +00001/*
2 * Copyright 2014 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
tfarinaf168b862014-06-19 12:32:29 -07008#include "GMBench.h"
commit-bot@chromium.org6adce672014-02-03 14:48:17 +00009
tfarinaf168b862014-06-19 12:32:29 -070010GMBench::GMBench(skiagm::GM* gm) : fGM(gm) {
commit-bot@chromium.org38aeb0f2014-02-26 23:01:57 +000011 fName.printf("GM:%s", gm->getName());
commit-bot@chromium.org6adce672014-02-03 14:48:17 +000012}
13
tfarinaf168b862014-06-19 12:32:29 -070014GMBench::~GMBench() { delete fGM; }
commit-bot@chromium.org6adce672014-02-03 14:48:17 +000015
tfarinaf168b862014-06-19 12:32:29 -070016const char* GMBench::onGetName() {
commit-bot@chromium.org6adce672014-02-03 14:48:17 +000017 return fName.c_str();
18}
19
tfarinaf168b862014-06-19 12:32:29 -070020bool GMBench::isSuitableFor(Backend backend) {
commit-bot@chromium.org6adce672014-02-03 14:48:17 +000021 uint32_t flags = fGM->getFlags();
22 switch (backend) {
23 case kGPU_Backend:
24 return !(skiagm::GM::kSkipGPU_Flag & flags);
25 case kPDF_Backend:
26 return !(skiagm::GM::kSkipPDF_Flag & flags);
27 case kRaster_Backend:
28 // GM doesn't have an equivalent flag. If the GM has known issues with 565 then
29 // we skip it for ALL raster configs in bench.
30 return !(skiagm::GM::kSkip565_Flag & flags);
31 case kNonRendering_Backend:
32 return false;
33 default:
34 SkDEBUGFAIL("Unexpected backend type.");
35 return false;
36 }
37}
38
tfarinaf168b862014-06-19 12:32:29 -070039void GMBench::onDraw(const int loops, SkCanvas* canvas) {
commit-bot@chromium.org6adce672014-02-03 14:48:17 +000040 // Do we care about timing the draw of the background (once)?
41 // Does the GM ever rely on drawBackground to lazily compute something?
42 fGM->drawBackground(canvas);
43 for (int i = 0; i < loops; ++i) {
44 fGM->drawContent(canvas);
45 }
46}
47
tfarinaf168b862014-06-19 12:32:29 -070048SkIPoint GMBench::onGetSize() {
commit-bot@chromium.org6adce672014-02-03 14:48:17 +000049 SkISize size = fGM->getISize();
50 return SkIPoint::Make(size.fWidth, size.fHeight);
51}