Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(72)

Side by Side Diff: dm/DMCpuTask.cpp

Issue 22839016: Skeleton of DM (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: one last sync Created 7 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « dm/DMCpuTask.h ('k') | dm/DMGpuTask.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 #include "DMCpuTask.h"
2 #include "DMReplayTask.h"
3 #include "DMUtil.h"
4 #include "SkCommandLineFlags.h"
5
6 DEFINE_bool(replay, false, "If true, run replay tests for each CpuTask.");
7 // TODO(mtklein): add the other various options
8
9 namespace DM {
10
11 CpuTask::CpuTask(const char* name,
12 Reporter* reporter,
13 TaskRunner* taskRunner,
14 const skiagm::ExpectationsSource& expectations,
15 skiagm::GMRegistry::Factory gmFactory,
16 SkBitmap::Config config)
17 : Task(reporter, taskRunner)
18 , fGMFactory(gmFactory)
19 , fGM(fGMFactory(NULL))
20 , fName(underJoin(fGM->shortName(), name))
21 , fExpectations(expectations.get(png(fName).c_str()))
22 , fConfig(config)
23 {}
24
25 void CpuTask::draw() {
26 SkBitmap bitmap;
27 bitmap.setConfig(fConfig, fGM->width(), fGM->height());
28 bitmap.allocPixels();
29 bitmap.eraseColor(0x00000000);
30 SkCanvas canvas(bitmap);
31
32 canvas.concat(fGM->getInitialTransform());
33 fGM->draw(&canvas);
34 canvas.flush();
35
36 const skiagm::GmResultDigest digest(bitmap);
37 if (!meetsExpectations(fExpectations, digest)) {
38 this->fail();
39 }
40
41 if (FLAGS_replay) {
42 this->spawnChild(SkNEW_ARGS(ReplayTask,
43 ("replay", *this, fGMFactory(NULL), digest, f Config)));
44 }
45 }
46
47 bool CpuTask::shouldSkip() const {
48 if (SkBitmap::kRGB_565_Config == fConfig && (fGM->getFlags() & skiagm::GM::k Skip565_Flag)) {
49 return true;
50 }
51 if (fGM->getFlags() & skiagm::GM::kGPUOnly_Flag) {
52 return true;
53 }
54 return false;
55 }
56
57 } // namespace DM
OLDNEW
« no previous file with comments | « dm/DMCpuTask.h ('k') | dm/DMGpuTask.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698