diff options
| author | Yong He <yonghe@outlook.com> | 2018-01-13 13:17:02 -0800 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-01-13 13:17:02 -0800 |
| commit | d4dab2cd3a409411c2d7caed01fc02a0fd3e8450 (patch) | |
| tree | 10c92df406a82e7a5eb24b56c17d9256a7183c44 /tests/compute/struct-in-generic.slang | |
| parent | df6eeb93c1718334779ae328db277cdf7a9d7b04 (diff) | |
| parent | 4d2086f47e25aa4545df95ddfd260c8bc5aafdb2 (diff) | |
Merge pull request #364 from csyonghe/assoctype
Support nested generics
Diffstat (limited to 'tests/compute/struct-in-generic.slang')
| -rw-r--r-- | tests/compute/struct-in-generic.slang | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/tests/compute/struct-in-generic.slang b/tests/compute/struct-in-generic.slang new file mode 100644 index 000000000..6f65f2ee3 --- /dev/null +++ b/tests/compute/struct-in-generic.slang @@ -0,0 +1,36 @@ +//TEST(compute):COMPARE_COMPUTE:-xslang -use-ir +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):dxbinding(0),glbinding(0),out + +// Confirm that a struct type defined in a generic parent works + +RWStructuredBuffer<float> outputBuffer; + +struct GenStruct<T> +{ + struct SubType + { + T x; + }; + T getVal(SubType v) + { + return v.x; + } +}; + +T test<T>(T val) +{ + GenStruct<T>.SubType sb; + sb.x = val; + GenStruct<T> obj; + return obj.getVal(sb); +} + + +[numthreads(4, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + uint tid = dispatchThreadID.x; + float inVal = float(tid); + float outVal = test(inVal); + outputBuffer[tid] = outVal.x; +}
\ No newline at end of file |
