xref: /aosp_15_r20/external/skia/tests/sksl/intrinsics/ClampFloat.metal (revision c8dee2aa9b3f27cf6c858bd81872bdeb2c07ed17)
1#include <metal_stdlib>
2#include <simd/simd.h>
3#ifdef __clang__
4#pragma clang diagnostic ignored "-Wall"
5#endif
6using namespace metal;
7struct Uniforms {
8    half4 testInputs;
9    half4 colorGreen;
10    half4 colorRed;
11};
12struct Inputs {
13};
14struct Outputs {
15    half4 sk_FragColor [[color(0)]];
16};
17fragment Outputs fragmentMain(Inputs _in [[stage_in]], constant Uniforms& _uniforms [[buffer(0)]], bool _frontFacing [[front_facing]], float4 _fragCoord [[position]]) {
18    Outputs _out;
19    (void)_out;
20    half4 expectedA = half4(-1.0h, 0.0h, 0.75h, 1.0h);
21    const half4 clampLow = half4(-1.0h, -2.0h, -2.0h, 1.0h);
22    half4 expectedB = half4(-1.0h, 0.0h, 0.5h, 2.25h);
23    const half4 clampHigh = half4(1.0h, 2.0h, 0.5h, 3.0h);
24    _out.sk_FragColor = ((((((((((((((clamp(_uniforms.testInputs.x, -1.0h, 1.0h) == expectedA.x && all(clamp(_uniforms.testInputs.xy, -1.0h, 1.0h) == expectedA.xy)) && all(clamp(_uniforms.testInputs.xyz, -1.0h, 1.0h) == expectedA.xyz)) && all(clamp(_uniforms.testInputs, -1.0h, 1.0h) == expectedA)) && clamp(_uniforms.testInputs.x, -1.0h, 1.0h) == expectedB.x) && all(clamp(_uniforms.testInputs.xy, half2(-1.0h, -2.0h), half2(1.0h, 2.0h)) == expectedB.xy)) && all(clamp(_uniforms.testInputs.xyz, half3(-1.0h, -2.0h, -2.0h), half3(1.0h, 2.0h, 0.5h)) == expectedB.xyz)) && all(clamp(_uniforms.testInputs, clampLow, clampHigh) == expectedB)) && -1.0h == expectedA.x) && all(half2(-1.0h, 0.0h) == expectedA.xy)) && all(half3(-1.0h, 0.0h, 0.75h) == expectedA.xyz)) && all(half4(-1.0h, 0.0h, 0.75h, 1.0h) == expectedA)) && -1.0h == expectedB.x) && all(half2(-1.0h, 0.0h) == expectedB.xy)) && all(half3(-1.0h, 0.0h, 0.5h) == expectedB.xyz)) && all(half4(-1.0h, 0.0h, 0.5h, 2.25h) == expectedB) ? _uniforms.colorGreen : _uniforms.colorRed;
25    return _out;
26}
27