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:
parent
8e5be413c1
commit
1c053644a8
@ -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());
|
||||||
|
@ -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;
|
||||||
|
@ -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)
|
||||||
|
@ -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));
|
||||||
|
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user