diff options
| author | ArielG-NV <159081215+ArielG-NV@users.noreply.github.com> | 2025-08-01 12:36:29 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-08-01 19:36:29 +0000 |
| commit | 8a15efb37a33d3c2943be87a19cbf9b5e2e8432b (patch) | |
| tree | 3ee02acbcfc4b53112427ce9febc2aa0d92815ed /tests/bugs | |
| parent | 6239a67cbeb3c551e08bfbf96044a0451e8ecc24 (diff) | |
Drain sink when single-argument constructor call fail (#7883)
* fix bug
* fix test
* push test changs for clarity
* fix bug
* fix test
* push test changs for clarity
* test what fails
* remove redundant code
Diffstat (limited to 'tests/bugs')
| -rw-r--r-- | tests/bugs/gh-7856.slang | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/tests/bugs/gh-7856.slang b/tests/bugs/gh-7856.slang new file mode 100644 index 000000000..b1edec8b5 --- /dev/null +++ b/tests/bugs/gh-7856.slang @@ -0,0 +1,52 @@ +//DIAGNOSTIC_TEST:SIMPLE(filecheck=CHECK): -target spirv -entry computeMain -stage compute + +enum A +{ + V1, + V2, + V3 +} + +enum B +{ + V1, + V2, + V3 +} + +struct Foo<T, A access = A::V1, B addrSpace = B::V1> +{ + int a; + __init(int b) { a = b; } + __init<U, A accessOther>(Foo<U, accessOther, addrSpace> ptr) + { + } + + // internally Slang is throwing an error, we just don't drain the error + // from our sink + __init(uint64_t val) {} + __init(int64_t val) {} +} + +extension int64_t +{ + __init<T, A access, B addrSpace>(Foo<T, access, addrSpace> t) {} +} +extension uint64_t +{ + __init<T, A access, B addrSpace>(Foo<T, access, addrSpace> t) {} +} + +RWStructuredBuffer<int> output; + +[shader("compute")] +[numthreads(1, 1, 1)] +void computeMain(uint3 threadId: SV_DispatchThreadID) +{ + Foo<int, A.V1, B.V1> v1 = Foo<int, A.V1, B.V1>(1); + + // CHECK: ([[# @LINE+1]]): error 30080 + Foo<float, A.V1, B.V2> v2 = Foo<float, A.V1, B.V2>(v1); + + output[0] = v1.a; +} |
