diff options
| author | jsmall-nvidia <jsmall@nvidia.com> | 2021-12-21 12:11:08 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-12-21 12:11:08 -0500 |
| commit | d7ed829c3f85514fc08a12a5701d64390b31040c (patch) | |
| tree | 4df957344ad0d5285359a2df541d69f76196b731 /tests/current-bugs/generic/tuple.slang | |
| parent | 48530f4c3505d1ab6269a5c21881492f059538d6 (diff) | |
Assorted disabled tests around generics (#2062)
* #include an absolute path didn't work - because paths were taken to always be relative.
* Some generic experiments.
* Add some more generic tests.
* More generic experiments/issues.
* Some more generic tests.
* Remove erroneous test.
* Small improvements.
* Disable test that was accidentally enabled.
* Add equality-2.slang.
* Some more generic tests.
* Issues around type inference.
* Some more generic tests.
* Tuple experiment.
* Generic interfaces don't seem to be supported.
* Add inheritance test.
* Alternative array type issue.
Diffstat (limited to 'tests/current-bugs/generic/tuple.slang')
| -rw-r--r-- | tests/current-bugs/generic/tuple.slang | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/current-bugs/generic/tuple.slang b/tests/current-bugs/generic/tuple.slang new file mode 100644 index 000000000..e5362ed6e --- /dev/null +++ b/tests/current-bugs/generic/tuple.slang @@ -0,0 +1,55 @@ +//DISABLE_TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -shaderobj + +/* Tuple experiment. + +Works. + */ + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name outputBuffer +RWStructuredBuffer<int> outputBuffer; + +struct Tuple2<T0, T1> +{ + T0 _0; + T1 _1; +}; + +struct Tuple3<T0, T1, T2> +{ + T0 _0; + T1 _1; + T2 _2; +}; + +Tuple2<T0, T1> makeTuple<T0, T1>(T0 t0, T1 t1) +{ + Tuple2<T0, T1> t; + t._0 = t0; + t._1 = t1; + return t; +} + +Tuple3<T0, T1, T2> makeTuple<T0, T1, T2>(T0 t0, T1 t1, T2 t2) +{ + Tuple3<T0, T1, T2> t; + t._0 = t0; + t._1 = t1; + t._2 = t2; + return t; +} + +int doThing(Tuple2<float, int> v) +{ + return v._0 + v._1; +} + +[numthreads(4, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + int index = dispatchThreadID.x; + + let t = makeTuple(index + 1.0f, index - 1); + + outputBuffer[index] = doThing(t); +} + |
