mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-06-01 12:11:34 +00:00
There's a reason the overload of `ctx.Replace()` that takes a pointer to the replacement is deprecated - it doesn't play well when used as part of another replacement. Switch to using the callback overload of Replace() to fix bad transform output. Bug: tint:1386647 Change-Id: I94292eeb65d24d7b2446b16b8b4ad13bdd27965a Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/111000 Auto-Submit: Ben Clayton <bclayton@google.com> Commit-Queue: James Price <jrprice@google.com> Reviewed-by: James Price <jrprice@google.com> Kokoro: Kokoro <noreply+kokoro@google.com>
27 lines
574 B
HLSL
27 lines
574 B
HLSL
[numthreads(1, 1, 1)]
|
|
void unused_entry_point() {
|
|
return;
|
|
}
|
|
|
|
static int a = 0;
|
|
static float b = 0.0f;
|
|
|
|
int tint_div(int lhs, int rhs) {
|
|
return (lhs / (((rhs == 0) | ((lhs == -2147483648) & (rhs == -1))) ? 1 : rhs));
|
|
}
|
|
|
|
int tint_mod(int lhs, int rhs) {
|
|
return (lhs % (((rhs == 0) | ((lhs == -2147483648) & (rhs == -1))) ? 1 : rhs));
|
|
}
|
|
|
|
void foo(int maybe_zero) {
|
|
a = tint_div(a, 0);
|
|
a = tint_mod(a, 0);
|
|
a = tint_div(a, maybe_zero);
|
|
a = tint_mod(a, maybe_zero);
|
|
b = (b / 0.0f);
|
|
b = (b % 0.0f);
|
|
b = (b / float(maybe_zero));
|
|
b = (b % float(maybe_zero));
|
|
}
|