skia2/tests/sksl/dslfp/GrDSLFPTest_IfStatement.h

39 lines
1.4 KiB
C
Raw Normal View History

Reland "Implement statements and expressions in DSL C++ code generator." This is a reland of 16cbfb41dff107ca3388bacf34201311d3c5f14d Tests now rely on `shaderDerivativeSupport` and `integerSupport` as proxies to indicate ES3 support. The SwitchStatement test has been adjusted to hopefully confuse fewer compilers. Original change's description: > Implement statements and expressions in DSL C++ code generator. > > This CL removes the bulk of the existing C++ code generator, especially > all the complex format-string assembly code. It has been replaced with > actual DSL code generation. Simple IR can now be successfully translated > to a working DSL fragment processor. > > This CL also adds a simple test harness which is patterned after the > existing SkSLTest; it renders a pixel, reads it back, and fails the test > if the result isn't solid green (RGBA=0101). > > This CL doesn't implement every feature. Some obvious gaps include: > - Sampling from children > - Uniforms/inputs of any kind > - Function calls of any kind > > Change-Id: Ib80c23fe1ba4453f7c3cb43b65f93c5ea0deb709 > Bug: skia:11854 > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/396757 > Reviewed-by: Ethan Nicholas <ethannicholas@google.com> > Reviewed-by: Brian Osman <brianosman@google.com> > Commit-Queue: John Stiles <johnstiles@google.com> Bug: skia:11854, skia:11891 Change-Id: I91363e31f34611d15ae350b52d6fc459feeace9c Reviewed-on: https://skia-review.googlesource.com/c/skia/+/399076 Auto-Submit: John Stiles <johnstiles@google.com> Commit-Queue: Ethan Nicholas <ethannicholas@google.com> Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
2021-04-21 19:04:27 +00:00
/**************************************************************************************************
Reland "Implement statements and expressions in DSL C++ code generator." This is a reland of 16cbfb41dff107ca3388bacf34201311d3c5f14d Tests now rely on `shaderDerivativeSupport` and `integerSupport` as proxies to indicate ES3 support. The SwitchStatement test has been adjusted to hopefully confuse fewer compilers. Original change's description: > Implement statements and expressions in DSL C++ code generator. > > This CL removes the bulk of the existing C++ code generator, especially > all the complex format-string assembly code. It has been replaced with > actual DSL code generation. Simple IR can now be successfully translated > to a working DSL fragment processor. > > This CL also adds a simple test harness which is patterned after the > existing SkSLTest; it renders a pixel, reads it back, and fails the test > if the result isn't solid green (RGBA=0101). > > This CL doesn't implement every feature. Some obvious gaps include: > - Sampling from children > - Uniforms/inputs of any kind > - Function calls of any kind > > Change-Id: Ib80c23fe1ba4453f7c3cb43b65f93c5ea0deb709 > Bug: skia:11854 > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/396757 > Reviewed-by: Ethan Nicholas <ethannicholas@google.com> > Reviewed-by: Brian Osman <brianosman@google.com> > Commit-Queue: John Stiles <johnstiles@google.com> Bug: skia:11854, skia:11891 Change-Id: I91363e31f34611d15ae350b52d6fc459feeace9c Reviewed-on: https://skia-review.googlesource.com/c/skia/+/399076 Auto-Submit: John Stiles <johnstiles@google.com> Commit-Queue: Ethan Nicholas <ethannicholas@google.com> Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
2021-04-21 19:04:27 +00:00
*** This file was autogenerated from GrDSLFPTest_IfStatement.fp; do not modify.
**************************************************************************************************/
Reland "Implement statements and expressions in DSL C++ code generator." This is a reland of 16cbfb41dff107ca3388bacf34201311d3c5f14d Tests now rely on `shaderDerivativeSupport` and `integerSupport` as proxies to indicate ES3 support. The SwitchStatement test has been adjusted to hopefully confuse fewer compilers. Original change's description: > Implement statements and expressions in DSL C++ code generator. > > This CL removes the bulk of the existing C++ code generator, especially > all the complex format-string assembly code. It has been replaced with > actual DSL code generation. Simple IR can now be successfully translated > to a working DSL fragment processor. > > This CL also adds a simple test harness which is patterned after the > existing SkSLTest; it renders a pixel, reads it back, and fails the test > if the result isn't solid green (RGBA=0101). > > This CL doesn't implement every feature. Some obvious gaps include: > - Sampling from children > - Uniforms/inputs of any kind > - Function calls of any kind > > Change-Id: Ib80c23fe1ba4453f7c3cb43b65f93c5ea0deb709 > Bug: skia:11854 > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/396757 > Reviewed-by: Ethan Nicholas <ethannicholas@google.com> > Reviewed-by: Brian Osman <brianosman@google.com> > Commit-Queue: John Stiles <johnstiles@google.com> Bug: skia:11854, skia:11891 Change-Id: I91363e31f34611d15ae350b52d6fc459feeace9c Reviewed-on: https://skia-review.googlesource.com/c/skia/+/399076 Auto-Submit: John Stiles <johnstiles@google.com> Commit-Queue: Ethan Nicholas <ethannicholas@google.com> Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
2021-04-21 19:04:27 +00:00
#ifndef GrDSLFPTest_IfStatement_DEFINED
#define GrDSLFPTest_IfStatement_DEFINED
#include "include/core/SkM44.h"
#include "include/core/SkTypes.h"
#include "src/gpu/GrFragmentProcessor.h"
Reland "Implement statements and expressions in DSL C++ code generator." This is a reland of 16cbfb41dff107ca3388bacf34201311d3c5f14d Tests now rely on `shaderDerivativeSupport` and `integerSupport` as proxies to indicate ES3 support. The SwitchStatement test has been adjusted to hopefully confuse fewer compilers. Original change's description: > Implement statements and expressions in DSL C++ code generator. > > This CL removes the bulk of the existing C++ code generator, especially > all the complex format-string assembly code. It has been replaced with > actual DSL code generation. Simple IR can now be successfully translated > to a working DSL fragment processor. > > This CL also adds a simple test harness which is patterned after the > existing SkSLTest; it renders a pixel, reads it back, and fails the test > if the result isn't solid green (RGBA=0101). > > This CL doesn't implement every feature. Some obvious gaps include: > - Sampling from children > - Uniforms/inputs of any kind > - Function calls of any kind > > Change-Id: Ib80c23fe1ba4453f7c3cb43b65f93c5ea0deb709 > Bug: skia:11854 > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/396757 > Reviewed-by: Ethan Nicholas <ethannicholas@google.com> > Reviewed-by: Brian Osman <brianosman@google.com> > Commit-Queue: John Stiles <johnstiles@google.com> Bug: skia:11854, skia:11891 Change-Id: I91363e31f34611d15ae350b52d6fc459feeace9c Reviewed-on: https://skia-review.googlesource.com/c/skia/+/399076 Auto-Submit: John Stiles <johnstiles@google.com> Commit-Queue: Ethan Nicholas <ethannicholas@google.com> Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
2021-04-21 19:04:27 +00:00
class GrDSLFPTest_IfStatement : public GrFragmentProcessor {
public:
static std::unique_ptr<GrFragmentProcessor> Make(float one) {
return std::unique_ptr<GrFragmentProcessor>(new GrDSLFPTest_IfStatement(one));
}
Reland "Implement statements and expressions in DSL C++ code generator." This is a reland of 16cbfb41dff107ca3388bacf34201311d3c5f14d Tests now rely on `shaderDerivativeSupport` and `integerSupport` as proxies to indicate ES3 support. The SwitchStatement test has been adjusted to hopefully confuse fewer compilers. Original change's description: > Implement statements and expressions in DSL C++ code generator. > > This CL removes the bulk of the existing C++ code generator, especially > all the complex format-string assembly code. It has been replaced with > actual DSL code generation. Simple IR can now be successfully translated > to a working DSL fragment processor. > > This CL also adds a simple test harness which is patterned after the > existing SkSLTest; it renders a pixel, reads it back, and fails the test > if the result isn't solid green (RGBA=0101). > > This CL doesn't implement every feature. Some obvious gaps include: > - Sampling from children > - Uniforms/inputs of any kind > - Function calls of any kind > > Change-Id: Ib80c23fe1ba4453f7c3cb43b65f93c5ea0deb709 > Bug: skia:11854 > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/396757 > Reviewed-by: Ethan Nicholas <ethannicholas@google.com> > Reviewed-by: Brian Osman <brianosman@google.com> > Commit-Queue: John Stiles <johnstiles@google.com> Bug: skia:11854, skia:11891 Change-Id: I91363e31f34611d15ae350b52d6fc459feeace9c Reviewed-on: https://skia-review.googlesource.com/c/skia/+/399076 Auto-Submit: John Stiles <johnstiles@google.com> Commit-Queue: Ethan Nicholas <ethannicholas@google.com> Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
2021-04-21 19:04:27 +00:00
GrDSLFPTest_IfStatement(const GrDSLFPTest_IfStatement& src);
std::unique_ptr<GrFragmentProcessor> clone() const override;
Reland "Implement statements and expressions in DSL C++ code generator." This is a reland of 16cbfb41dff107ca3388bacf34201311d3c5f14d Tests now rely on `shaderDerivativeSupport` and `integerSupport` as proxies to indicate ES3 support. The SwitchStatement test has been adjusted to hopefully confuse fewer compilers. Original change's description: > Implement statements and expressions in DSL C++ code generator. > > This CL removes the bulk of the existing C++ code generator, especially > all the complex format-string assembly code. It has been replaced with > actual DSL code generation. Simple IR can now be successfully translated > to a working DSL fragment processor. > > This CL also adds a simple test harness which is patterned after the > existing SkSLTest; it renders a pixel, reads it back, and fails the test > if the result isn't solid green (RGBA=0101). > > This CL doesn't implement every feature. Some obvious gaps include: > - Sampling from children > - Uniforms/inputs of any kind > - Function calls of any kind > > Change-Id: Ib80c23fe1ba4453f7c3cb43b65f93c5ea0deb709 > Bug: skia:11854 > Reviewed-on: https://skia-review.googlesource.com/c/skia/+/396757 > Reviewed-by: Ethan Nicholas <ethannicholas@google.com> > Reviewed-by: Brian Osman <brianosman@google.com> > Commit-Queue: John Stiles <johnstiles@google.com> Bug: skia:11854, skia:11891 Change-Id: I91363e31f34611d15ae350b52d6fc459feeace9c Reviewed-on: https://skia-review.googlesource.com/c/skia/+/399076 Auto-Submit: John Stiles <johnstiles@google.com> Commit-Queue: Ethan Nicholas <ethannicholas@google.com> Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
2021-04-21 19:04:27 +00:00
const char* name() const override { return "DSLFPTest_IfStatement"; }
float one;
private:
GrDSLFPTest_IfStatement(float one)
: INHERITED(kGrDSLFPTest_IfStatement_ClassID, kNone_OptimizationFlags)
, one(one) {
}
std::unique_ptr<GrGLSLFragmentProcessor> onMakeProgramImpl() const override;
void onGetGLSLProcessorKey(const GrShaderCaps&, GrProcessorKeyBuilder*) const override;
bool onIsEqual(const GrFragmentProcessor&) const override;
#if GR_TEST_UTILS
SkString onDumpInfo() const override;
#endif
GR_DECLARE_FRAGMENT_PROCESSOR_TEST
using INHERITED = GrFragmentProcessor;
};
#endif