Make GrProcessorTestFactory be templated on smart ptr class rather than processor class.

This is part of setting the stage for moving GrFragmentProcessor to unique_ptr ownership.

Change-Id: I2dfb4977319605d56c4debe05ff0b3dc970bb4c5
Reviewed-on: https://skia-review.googlesource.com/26141
Reviewed-by: Robert Phillips <robertphillips@google.com>
Commit-Queue: Brian Salomon <bsalomon@google.com>
This commit is contained in:
Brian Salomon 2017-07-24 10:16:19 -04:00 committed by Skia Commit-Bot
parent 8e5be413c1
commit 1c053644a8
5 changed files with 36 additions and 33 deletions

View File

@ -33,17 +33,15 @@ class GrGeometryProcessor;
* Originally these were both in the processor unit test header, but then it seemed to cause linker * Originally these were both in the processor unit test header, but then it seemed to cause linker
* problems on android. * problems on android.
*/ */
template<> template <>
SkTArray<GrProcessorTestFactory<GrFragmentProcessor>*, true>* SkTArray<GrFragmentProcessorTestFactory*, true>* GrFragmentProcessorTestFactory::GetFactories() {
GrProcessorTestFactory<GrFragmentProcessor>::GetFactories() { static SkTArray<GrFragmentProcessorTestFactory*, true> gFactories;
static SkTArray<GrProcessorTestFactory<GrFragmentProcessor>*, true> gFactories;
return &gFactories; return &gFactories;
} }
template<> template <>
SkTArray<GrProcessorTestFactory<GrGeometryProcessor>*, true>* SkTArray<GrGeometryProcessorTestFactory*, true>* GrGeometryProcessorTestFactory::GetFactories() {
GrProcessorTestFactory<GrGeometryProcessor>::GetFactories() { static SkTArray<GrGeometryProcessorTestFactory*, true> gFactories;
static SkTArray<GrProcessorTestFactory<GrGeometryProcessor>*, true> gFactories;
return &gFactories; return &gFactories;
} }
@ -61,8 +59,8 @@ static const int kFPFactoryCount = 42;
static const int kGPFactoryCount = 14; static const int kGPFactoryCount = 14;
static const int kXPFactoryCount = 4; static const int kXPFactoryCount = 4;
template<> template <>
void GrProcessorTestFactory<GrFragmentProcessor>::VerifyFactoryCount() { void GrFragmentProcessorTestFactory::VerifyFactoryCount() {
if (kFPFactoryCount != GetFactories()->count()) { if (kFPFactoryCount != GetFactories()->count()) {
SkDebugf("\nExpected %d fragment processor factories, found %d.\n", SkDebugf("\nExpected %d fragment processor factories, found %d.\n",
kFPFactoryCount, GetFactories()->count()); kFPFactoryCount, GetFactories()->count());
@ -70,8 +68,8 @@ void GrProcessorTestFactory<GrFragmentProcessor>::VerifyFactoryCount() {
} }
} }
template<> template <>
void GrProcessorTestFactory<GrGeometryProcessor>::VerifyFactoryCount() { void GrGeometryProcessorTestFactory::VerifyFactoryCount() {
if (kGPFactoryCount != GetFactories()->count()) { if (kGPFactoryCount != GetFactories()->count()) {
SkDebugf("\nExpected %d geometry processor factories, found %d.\n", SkDebugf("\nExpected %d geometry processor factories, found %d.\n",
kGPFactoryCount, GetFactories()->count()); kGPFactoryCount, GetFactories()->count());

View File

@ -14,7 +14,7 @@ sk_sp<GrFragmentProcessor> GrProcessorUnitTest::MakeChildFP(GrProcessorTestData*
#if SK_ALLOW_STATIC_GLOBAL_INITIALIZERS #if SK_ALLOW_STATIC_GLOBAL_INITIALIZERS
sk_sp<GrFragmentProcessor> fp; sk_sp<GrFragmentProcessor> fp;
do { do {
fp = GrProcessorTestFactory<GrFragmentProcessor>::Make(data); fp = GrFragmentProcessorTestFactory::Make(data);
SkASSERT(fp); SkASSERT(fp);
} while (fp->numChildProcessors() != 0); } while (fp->numChildProcessors() != 0);
return fp; return fp;

View File

@ -23,6 +23,7 @@ class GrRenderTargetContext;
struct GrProcessorTestData; struct GrProcessorTestData;
class GrTexture; class GrTexture;
class GrXPFactory; class GrXPFactory;
class GrGeometryProcessor;
namespace GrProcessorUnitTest { namespace GrProcessorUnitTest {
@ -75,9 +76,11 @@ private:
class GrProcessor; class GrProcessor;
class GrTexture; class GrTexture;
template <class Processor> class GrProcessorTestFactory : private SkNoncopyable { template <class ProcessorSmartPtr>
class GrProcessorTestFactory : private SkNoncopyable {
public: public:
typedef sk_sp<Processor> (*MakeProc)(GrProcessorTestData*); using Processor = typename ProcessorSmartPtr::element_type;
using MakeProc = ProcessorSmartPtr (*)(GrProcessorTestData*);
GrProcessorTestFactory(MakeProc makeProc) { GrProcessorTestFactory(MakeProc makeProc) {
fMakeProc = makeProc; fMakeProc = makeProc;
@ -85,7 +88,7 @@ public:
} }
/** Pick a random factory function and create a processor. */ /** Pick a random factory function and create a processor. */
static sk_sp<Processor> Make(GrProcessorTestData* data) { static ProcessorSmartPtr Make(GrProcessorTestData* data) {
VerifyFactoryCount(); VerifyFactoryCount();
SkASSERT(GetFactories()->count()); SkASSERT(GetFactories()->count());
uint32_t idx = data->fRandom->nextRangeU(0, GetFactories()->count() - 1); uint32_t idx = data->fRandom->nextRangeU(0, GetFactories()->count() - 1);
@ -97,8 +100,8 @@ public:
/** Use factory function at Index idx to create a processor. */ /** Use factory function at Index idx to create a processor. */
static sk_sp<Processor> MakeIdx(int idx, GrProcessorTestData* data) { static sk_sp<Processor> MakeIdx(int idx, GrProcessorTestData* data) {
GrProcessorTestFactory<Processor>* factory = (*GetFactories())[idx]; GrProcessorTestFactory<ProcessorSmartPtr>* factory = (*GetFactories())[idx];
sk_sp<Processor> processor = factory->fMakeProc(data); ProcessorSmartPtr processor = factory->fMakeProc(data);
SkASSERT(processor); SkASSERT(processor);
return processor; return processor;
} }
@ -111,9 +114,12 @@ private:
MakeProc fMakeProc; MakeProc fMakeProc;
static SkTArray<GrProcessorTestFactory<Processor>*, true>* GetFactories(); static SkTArray<GrProcessorTestFactory<ProcessorSmartPtr>*, true>* GetFactories();
}; };
using GrFragmentProcessorTestFactory = GrProcessorTestFactory<sk_sp<GrFragmentProcessor>>;
using GrGeometryProcessorTestFactory = GrProcessorTestFactory<sk_sp<GrGeometryProcessor>>;
class GrXPFactoryTestFactory : private SkNoncopyable { class GrXPFactoryTestFactory : private SkNoncopyable {
public: public:
using GetFn = const GrXPFactory*(GrProcessorTestData*); using GetFn = const GrXPFactory*(GrProcessorTestData*);
@ -140,11 +146,11 @@ private:
* program generation unit test. * program generation unit test.
*/ */
#define GR_DECLARE_GEOMETRY_PROCESSOR_TEST \ #define GR_DECLARE_GEOMETRY_PROCESSOR_TEST \
static GrProcessorTestFactory<GrGeometryProcessor> gTestFactory SK_UNUSED; \ static GrGeometryProcessorTestFactory gTestFactory SK_UNUSED; \
static sk_sp<GrGeometryProcessor> TestCreate(GrProcessorTestData*); static sk_sp<GrGeometryProcessor> TestCreate(GrProcessorTestData*);
#define GR_DECLARE_FRAGMENT_PROCESSOR_TEST \ #define GR_DECLARE_FRAGMENT_PROCESSOR_TEST \
static GrProcessorTestFactory<GrFragmentProcessor> gTestFactory SK_UNUSED; \ static GrFragmentProcessorTestFactory gTestFactory SK_UNUSED; \
static sk_sp<GrFragmentProcessor> TestCreate(GrProcessorTestData*); static sk_sp<GrFragmentProcessor> TestCreate(GrProcessorTestData*);
#define GR_DECLARE_XP_FACTORY_TEST \ #define GR_DECLARE_XP_FACTORY_TEST \
@ -156,10 +162,10 @@ private:
* GrProcessor* TestCreate(GrProcessorTestData*); * GrProcessor* TestCreate(GrProcessorTestData*);
*/ */
#define GR_DEFINE_FRAGMENT_PROCESSOR_TEST(Effect) \ #define GR_DEFINE_FRAGMENT_PROCESSOR_TEST(Effect) \
GrProcessorTestFactory<GrFragmentProcessor> Effect::gTestFactory(Effect::TestCreate) GrFragmentProcessorTestFactory Effect::gTestFactory(Effect::TestCreate)
#define GR_DEFINE_GEOMETRY_PROCESSOR_TEST(Effect) \ #define GR_DEFINE_GEOMETRY_PROCESSOR_TEST(Effect) \
GrProcessorTestFactory<GrGeometryProcessor> Effect::gTestFactory(Effect::TestCreate) GrGeometryProcessorTestFactory Effect::gTestFactory(Effect::TestCreate)
#define GR_DEFINE_XP_FACTORY_TEST(Factory) \ #define GR_DEFINE_XP_FACTORY_TEST(Factory) \
GrXPFactoryTestFactory Factory::gTestFactory(Factory::TestGet) GrXPFactoryTestFactory Factory::gTestFactory(Factory::TestGet)

View File

@ -177,7 +177,7 @@ static sk_sp<GrFragmentProcessor> create_random_proc_tree(GrProcessorTestData* d
if (terminate) { if (terminate) {
sk_sp<GrFragmentProcessor> fp; sk_sp<GrFragmentProcessor> fp;
while (true) { while (true) {
fp = GrProcessorTestFactory<GrFragmentProcessor>::Make(d); fp = GrFragmentProcessorTestFactory::Make(d);
SkASSERT(fp); SkASSERT(fp);
if (0 == fp->numChildProcessors()) { if (0 == fp->numChildProcessors()) {
break; break;
@ -225,7 +225,7 @@ static void set_random_color_coverage_stages(GrPaint* paint,
int numColorProcs = d->fRandom->nextULessThan(numProcs + 1); int numColorProcs = d->fRandom->nextULessThan(numProcs + 1);
for (int s = 0; s < numProcs;) { for (int s = 0; s < numProcs;) {
sk_sp<GrFragmentProcessor> fp(GrProcessorTestFactory<GrFragmentProcessor>::Make(d)); sk_sp<GrFragmentProcessor> fp(GrFragmentProcessorTestFactory::Make(d));
SkASSERT(fp); SkASSERT(fp);
// finally add the stage to the correct pipeline in the drawstate // finally add the stage to the correct pipeline in the drawstate
@ -316,7 +316,7 @@ bool GrDrawingManager::ProgramUnitTest(GrContext* context, int maxStages, int ma
return false; return false;
} }
int fpFactoryCnt = GrProcessorTestFactory<GrFragmentProcessor>::Count(); int fpFactoryCnt = GrFragmentProcessorTestFactory::Count();
for (int i = 0; i < fpFactoryCnt; ++i) { for (int i = 0; i < fpFactoryCnt; ++i) {
// Since FP factories internally randomize, call each 10 times. // Since FP factories internally randomize, call each 10 times.
for (int j = 0; j < 10; ++j) { for (int j = 0; j < 10; ++j) {
@ -324,8 +324,7 @@ bool GrDrawingManager::ProgramUnitTest(GrContext* context, int maxStages, int ma
GrPaint paint; GrPaint paint;
paint.setXPFactory(GrPorterDuffXPFactory::Get(SkBlendMode::kSrc)); paint.setXPFactory(GrPorterDuffXPFactory::Get(SkBlendMode::kSrc));
sk_sp<GrFragmentProcessor> fp( sk_sp<GrFragmentProcessor> fp(GrFragmentProcessorTestFactory::MakeIdx(i, &ptd));
GrProcessorTestFactory<GrFragmentProcessor>::MakeIdx(i, &ptd));
sk_sp<GrFragmentProcessor> blockFP( sk_sp<GrFragmentProcessor> blockFP(
BlockInputFragmentProcessor::Make(std::move(fp))); BlockInputFragmentProcessor::Make(std::move(fp)));
paint.addColorFragmentProcessor(std::move(blockFP)); paint.addColorFragmentProcessor(std::move(blockFP));

View File

@ -288,7 +288,7 @@ DEFINE_bool(randomProcessorTest, false, "Use non-deterministic seed for random p
#if GR_TEST_UTILS #if GR_TEST_UTILS
DEF_GPUTEST_FOR_GL_RENDERING_CONTEXTS(ProcessorOptimizationValidationTest, reporter, ctxInfo) { DEF_GPUTEST_FOR_GL_RENDERING_CONTEXTS(ProcessorOptimizationValidationTest, reporter, ctxInfo) {
GrContext* context = ctxInfo.grContext(); GrContext* context = ctxInfo.grContext();
using FPFactory = GrProcessorTestFactory<GrFragmentProcessor>; using FPFactory = GrFragmentProcessorTestFactory;
uint32_t seed = 0; uint32_t seed = 0;
if (FLAGS_randomProcessorTest) { if (FLAGS_randomProcessorTest) {