923d83bf18
`optimize_comparison` asserted that its inputs were numbers. However, it's also valid to compare boolean inputs. Fortunately, other than the over-zealous assertion, the actual logic worked fine. Change-Id: I8a9db000274b4993a4c303efa223a1ed72461a87 Bug: oss-fuzz:39513 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/455296 Auto-Submit: John Stiles <johnstiles@google.com> Commit-Queue: Brian Osman <brianosman@google.com> Reviewed-by: Brian Osman <brianosman@google.com>
15 lines
506 B
Plaintext
15 lines
506 B
Plaintext
uniform half4 a, b;
|
|
uniform uint2 c, d;
|
|
uniform int3 e, f;
|
|
void main() {
|
|
const int4 int4_zero = int4(0);
|
|
bool4 expectTTFF = equal(half4(3, 3, 3.25, 100), half4(3));
|
|
bool4 expectFFTT = equal(int4_zero, int4(-100, -50, 0, 0));
|
|
bool4 expectTTTT = equal(bool4(1), bool4(7));
|
|
|
|
sk_FragColor.x = equal(a, b).x ? 1 : 0;
|
|
sk_FragColor.y = equal(c, d).y ? 1 : 0;
|
|
sk_FragColor.z = equal(e, f).z ? 1 : 0;
|
|
sk_FragColor.w = any(expectTTFF) || any(expectFFTT) || any(expectTTTT) ? 1 : 0;
|
|
}
|