2022-03-28 14:36:31 +00:00
|
|
|
#version 310 es
|
|
|
|
|
2022-11-09 22:04:11 +00:00
|
|
|
ivec3 tint_mod(ivec3 lhs, int rhs) {
|
|
|
|
ivec3 r = ivec3(rhs);
|
2023-02-10 15:01:02 +00:00
|
|
|
ivec3 rhs_or_one = mix(r, ivec3(1), bvec3(uvec3(equal(r, ivec3(0))) | uvec3(bvec3(uvec3(equal(lhs, ivec3(-2147483648))) & uvec3(equal(r, ivec3(-1)))))));
|
|
|
|
if (any(notEqual((uvec3((lhs | rhs_or_one)) & uvec3(2147483648u)), uvec3(0u)))) {
|
|
|
|
return (lhs - ((lhs / rhs_or_one) * rhs_or_one));
|
|
|
|
} else {
|
|
|
|
return (lhs % rhs_or_one);
|
|
|
|
}
|
2022-11-09 22:04:11 +00:00
|
|
|
}
|
|
|
|
|
2022-03-28 14:36:31 +00:00
|
|
|
void f() {
|
|
|
|
ivec3 a = ivec3(1, 2, 3);
|
2022-09-19 14:05:21 +00:00
|
|
|
int b = 4;
|
2022-11-09 22:04:11 +00:00
|
|
|
ivec3 r = tint_mod(a, b);
|
2022-03-28 14:36:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
|
|
|
|
void main() {
|
|
|
|
f();
|
|
|
|
return;
|
|
|
|
}
|