Index: bench/XfermodeBench.cpp |
diff --git a/bench/XfermodeBench.cpp b/bench/XfermodeBench.cpp |
index 0d85fefe1fbb9bc48973b5bfe8a23351b1818d80..71cf0e69b5dc0d3f0b8062992dee72ea400687ba 100644 |
--- a/bench/XfermodeBench.cpp |
+++ b/bench/XfermodeBench.cpp |
@@ -12,6 +12,7 @@ |
#include "SkRandom.h" |
#include "SkString.h" |
#include "SkXfermode.h" |
+#include "SkLumaXfermode.h" |
// Benchmark that draws non-AA rects with an SkXfermode::Mode |
class XfermodeBench : public SkBenchmark { |
@@ -22,6 +23,13 @@ public: |
fName.printf("Xfermode_%s", SkXfermode::ModeName(mode)); |
} |
+ XfermodeBench(void* param, SkXfermode* xferMode, const char* name) |
+ : SkBenchmark(param) { |
+ SkASSERT(NULL != xferMode); |
+ fXfermode.reset(xferMode); |
+ fName.printf("Xfermode_%s", name); |
+ } |
+ |
protected: |
virtual const char* onGetName() SK_OVERRIDE { return fName.c_str(); } |
@@ -58,62 +66,44 @@ private: |
////////////////////////////////////////////////////////////////////////////// |
-static SkBenchmark* Fact00(void* p) { return new XfermodeBench(p, SkXfermode::kClear_Mode); } |
-static SkBenchmark* Fact01(void* p) { return new XfermodeBench(p, SkXfermode::kSrc_Mode); } |
-static SkBenchmark* Fact02(void* p) { return new XfermodeBench(p, SkXfermode::kDst_Mode); } |
-static SkBenchmark* Fact03(void* p) { return new XfermodeBench(p, SkXfermode::kSrcOver_Mode); } |
-static SkBenchmark* Fact04(void* p) { return new XfermodeBench(p, SkXfermode::kDstOver_Mode); } |
-static SkBenchmark* Fact05(void* p) { return new XfermodeBench(p, SkXfermode::kSrcIn_Mode); } |
-static SkBenchmark* Fact06(void* p) { return new XfermodeBench(p, SkXfermode::kDstIn_Mode); } |
-static SkBenchmark* Fact07(void* p) { return new XfermodeBench(p, SkXfermode::kSrcOut_Mode); } |
-static SkBenchmark* Fact08(void* p) { return new XfermodeBench(p, SkXfermode::kDstOut_Mode); } |
-static SkBenchmark* Fact09(void* p) { return new XfermodeBench(p, SkXfermode::kSrcATop_Mode); } |
-static SkBenchmark* Fact10(void* p) { return new XfermodeBench(p, SkXfermode::kDstATop_Mode); } |
-static SkBenchmark* Fact11(void* p) { return new XfermodeBench(p, SkXfermode::kXor_Mode); } |
-static SkBenchmark* Fact12(void* p) { return new XfermodeBench(p, SkXfermode::kPlus_Mode); } |
-static SkBenchmark* Fact13(void* p) { return new XfermodeBench(p, SkXfermode::kModulate_Mode); } |
-static SkBenchmark* Fact14(void* p) { return new XfermodeBench(p, SkXfermode::kScreen_Mode); } |
-static SkBenchmark* Fact15(void* p) { return new XfermodeBench(p, SkXfermode::kOverlay_Mode); } |
-static SkBenchmark* Fact16(void* p) { return new XfermodeBench(p, SkXfermode::kDarken_Mode); } |
-static SkBenchmark* Fact17(void* p) { return new XfermodeBench(p, SkXfermode::kLighten_Mode); } |
-static SkBenchmark* Fact18(void* p) { return new XfermodeBench(p, SkXfermode::kColorDodge_Mode); } |
-static SkBenchmark* Fact19(void* p) { return new XfermodeBench(p, SkXfermode::kColorBurn_Mode); } |
-static SkBenchmark* Fact20(void* p) { return new XfermodeBench(p, SkXfermode::kHardLight_Mode); } |
-static SkBenchmark* Fact21(void* p) { return new XfermodeBench(p, SkXfermode::kSoftLight_Mode); } |
-static SkBenchmark* Fact22(void* p) { return new XfermodeBench(p, SkXfermode::kDifference_Mode); } |
-static SkBenchmark* Fact23(void* p) { return new XfermodeBench(p, SkXfermode::kExclusion_Mode); } |
-static SkBenchmark* Fact24(void* p) { return new XfermodeBench(p, SkXfermode::kMultiply_Mode); } |
-static SkBenchmark* Fact25(void* p) { return new XfermodeBench(p, SkXfermode::kHue_Mode); } |
-static SkBenchmark* Fact26(void* p) { return new XfermodeBench(p, SkXfermode::kSaturation_Mode); } |
-static SkBenchmark* Fact27(void* p) { return new XfermodeBench(p, SkXfermode::kColor_Mode); } |
-static SkBenchmark* Fact28(void* p) { return new XfermodeBench(p, SkXfermode::kLuminosity_Mode); } |
+#define CONCAT_I(x, y) x ## y |
+#define CONCAT(x, y) CONCAT_I(x, y) // allow for macro expansion |
+#define BENCH(...) \ |
+ static SkBenchmark* CONCAT(Fact, __LINE__)(void *p) { return new XfermodeBench(p, __VA_ARGS__); };\ |
+ static BenchRegistry CONCAT(gReg, __LINE__)(CONCAT(Fact, __LINE__)); |
+ |
+BENCH(SkXfermode::kClear_Mode) |
+BENCH(SkXfermode::kSrc_Mode) |
+BENCH(SkXfermode::kDst_Mode) |
+BENCH(SkXfermode::kSrcOver_Mode) |
+BENCH(SkXfermode::kDstOver_Mode) |
+BENCH(SkXfermode::kSrcIn_Mode) |
+BENCH(SkXfermode::kDstIn_Mode) |
+BENCH(SkXfermode::kSrcOut_Mode) |
+BENCH(SkXfermode::kDstOut_Mode) |
+BENCH(SkXfermode::kSrcATop_Mode) |
+BENCH(SkXfermode::kDstATop_Mode) |
+BENCH(SkXfermode::kXor_Mode) |
+ |
+BENCH(SkXfermode::kPlus_Mode) |
+BENCH(SkXfermode::kModulate_Mode) |
+BENCH(SkXfermode::kScreen_Mode) |
+ |
+BENCH(SkXfermode::kOverlay_Mode) |
+BENCH(SkXfermode::kDarken_Mode) |
+BENCH(SkXfermode::kLighten_Mode) |
+BENCH(SkXfermode::kColorDodge_Mode) |
+BENCH(SkXfermode::kColorBurn_Mode) |
+BENCH(SkXfermode::kHardLight_Mode) |
+BENCH(SkXfermode::kSoftLight_Mode) |
+BENCH(SkXfermode::kDifference_Mode) |
+BENCH(SkXfermode::kExclusion_Mode) |
+BENCH(SkXfermode::kMultiply_Mode) |
+ |
+BENCH(SkXfermode::kHue_Mode) |
+BENCH(SkXfermode::kSaturation_Mode) |
+BENCH(SkXfermode::kColor_Mode) |
+BENCH(SkXfermode::kLuminosity_Mode) |
-static BenchRegistry gReg00(Fact00); |
-static BenchRegistry gReg01(Fact01); |
-static BenchRegistry gReg02(Fact02); |
-static BenchRegistry gReg03(Fact03); |
-static BenchRegistry gReg04(Fact04); |
-static BenchRegistry gReg05(Fact05); |
-static BenchRegistry gReg06(Fact06); |
-static BenchRegistry gReg07(Fact07); |
-static BenchRegistry gReg08(Fact08); |
-static BenchRegistry gReg09(Fact09); |
-static BenchRegistry gReg10(Fact10); |
-static BenchRegistry gReg11(Fact11); |
-static BenchRegistry gReg12(Fact12); |
-static BenchRegistry gReg13(Fact13); |
-static BenchRegistry gReg14(Fact14); |
-static BenchRegistry gReg15(Fact15); |
-static BenchRegistry gReg16(Fact16); |
-static BenchRegistry gReg17(Fact17); |
-static BenchRegistry gReg18(Fact18); |
-static BenchRegistry gReg19(Fact19); |
-static BenchRegistry gReg20(Fact20); |
-static BenchRegistry gReg21(Fact21); |
-static BenchRegistry gReg22(Fact22); |
-static BenchRegistry gReg23(Fact23); |
-static BenchRegistry gReg24(Fact24); |
-static BenchRegistry gReg25(Fact25); |
-static BenchRegistry gReg26(Fact26); |
-static BenchRegistry gReg27(Fact27); |
-static BenchRegistry gReg28(Fact28); |
+BENCH(SkLumaMaskXfermode::Create(SkXfermode::kSrcIn_Mode), "SrcInLuma") |
+BENCH(SkLumaMaskXfermode::Create(SkXfermode::kDstIn_Mode), "DstInLuma") |