skia2/resources/sksl/dslfp/GrDSLFPTest_IfStatement.fp
John Stiles 956802335d Reland "Reland "Implement statements and expressions in DSL C++ code generator.""
This is a reland of c412688798

This CL lands the code changes but not the dm test, which is causing
link errors. Tests will be relanded as a separate CL, at
http://review.skia.org/400097

Original change's description:
> Reland "Implement statements and expressions in DSL C++ code generator."
>
> This is a reland of 16cbfb41df
>
> 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>

Bug: skia:11854
Bug: skia:11891
Change-Id: Ib1f08256c84d1da2130e0b61356f72435dc0a5a8
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/399740
Reviewed-by: Ethan Nicholas <ethannicholas@google.com>
Commit-Queue: Ethan Nicholas <ethannicholas@google.com>
Commit-Queue: John Stiles <johnstiles@google.com>
Auto-Submit: John Stiles <johnstiles@google.com>
2021-04-22 20:01:33 +00:00

43 lines
1.2 KiB
GLSL

half4 main() {
half4 color = half4(0);
// Basic if statement. (00 == 00: true --> color=0001)
if (color.rg == color.ba) color.a = 1;
// Basic if statement with Block. (00 == 01: false)
if (color.rg == color.ba) {
color.r = color.a;
}
// TODO(skia:11872): Add test for If statement with comma-expression statement instead of Block.
// Basic if-else statement. (0 == 0: true --> color=1011)
if (color.r == color.g) color = color.araa; else color = color.rrra;
// Chained if-else statements.
if (color.r + color.g + color.b + color.a == 1) { // (3 == 1: false)
color = half4(-1);
} else if (color.r + color.g + color.b + color.a == 2) { // (3 == 2: false)
color = half4(-2);
} else {
color = color.ggaa; // (color=0011)
}
// Nested if-else statements.
if (color.r == 1) { // (0 == 1: false)
if (color.r == 2) {
color = color.rrrr;
} else {
color = color.gggg;
}
} else {
if (color.b * color.a == 1) { // (1*1 == 1: true)
color = color.rbga; // (color = 0101)
} else {
color = color.aaaa;
}
}
return color;
}