skia2/tests/sksl/shared/ScalarConversionConstructorsES3.metal
Brian Osman 58134e1408 Fix const globals in Metal
We were emitting this at global scope (not in Globals). That would lead
to errors about the variable needing to be in the constant address
space. (You can see the result in ConstArray.metal - the old code was
invalid). Also, we were already making references use _globals, so the
code was double-wrong (or half-right, depending on your perspective).

After the core change, writeVarDeclaration was only used for local
scope, and writeModifiers never used the 'globalContext' parameter.

The removal of finishLine() changed every test output, unfortunately.

Change-Id: Icc1356ba2cc3c339b2f5759b3d18523fd39395bc
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/408356
Commit-Queue: Brian Osman <brianosman@google.com>
Reviewed-by: John Stiles <johnstiles@google.com>
2021-05-13 21:11:10 +00:00

39 lines
1.2 KiB
Metal

#include <metal_stdlib>
#include <simd/simd.h>
using namespace metal;
struct Uniforms {
float4 colorGreen;
float4 colorRed;
};
struct Inputs {
};
struct Outputs {
float4 sk_FragColor [[color(0)]];
};
fragment Outputs fragmentMain(Inputs _in [[stage_in]], constant Uniforms& _uniforms [[buffer(0)]], bool _frontFacing [[front_facing]], float4 _fragCoord [[position]]) {
Outputs _out;
(void)_out;
float f = _uniforms.colorGreen.y;
int i = int(_uniforms.colorGreen.y);
uint u = uint(_uniforms.colorGreen.y);
bool b = bool(_uniforms.colorGreen.y);
float f1 = f;
float f2 = float(i);
float f3 = float(u);
float f4 = float(b);
int i1 = int(f);
int i2 = i;
int i3 = int(u);
int i4 = int(b);
uint u1 = uint(f);
uint u2 = uint(i);
uint u3 = u;
uint u4 = uint(b);
bool b1 = bool(f);
bool b2 = bool(i);
bool b3 = bool(u);
bool b4 = b;
_out.sk_FragColor = ((((((((((((((f1 + f2) + f3) + f4) + float(i1)) + float(i2)) + float(i3)) + float(i4)) + float(u1)) + float(u2)) + float(u3)) + float(u4)) + float(b1)) + float(b2)) + float(b3)) + float(b4) == 16.0 ? _uniforms.colorGreen : _uniforms.colorRed;
return _out;
}