From 4b284daeb0cc3f6df0835befad4326c81abeb374 Mon Sep 17 00:00:00 2001 From: Yong He Date: Tue, 9 Jan 2018 13:26:42 -0800 Subject: Support nested generics fixes #362 --- tests/compute/nested-generics.slang | 40 ++++++++++++++++++++ tests/compute/nested-generics.slang.expected.txt | 4 ++ tests/compute/nested-generics2.slang | 43 ++++++++++++++++++++++ tests/compute/nested-generics2.slang.expected.txt | 4 ++ tests/compute/struct-in-generic.slang | 36 ++++++++++++++++++ tests/compute/struct-in-generic.slang.expected.txt | 4 ++ 6 files changed, 131 insertions(+) create mode 100644 tests/compute/nested-generics.slang create mode 100644 tests/compute/nested-generics.slang.expected.txt create mode 100644 tests/compute/nested-generics2.slang create mode 100644 tests/compute/nested-generics2.slang.expected.txt create mode 100644 tests/compute/struct-in-generic.slang create mode 100644 tests/compute/struct-in-generic.slang.expected.txt (limited to 'tests/compute') diff --git a/tests/compute/nested-generics.slang b/tests/compute/nested-generics.slang new file mode 100644 index 000000000..63b6db4fe --- /dev/null +++ b/tests/compute/nested-generics.slang @@ -0,0 +1,40 @@ +//TEST(compute):COMPARE_COMPUTE:-xslang -use-ir +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):dxbinding(0),glbinding(0),out + +// test specialization of nested generic functions + +RWStructuredBuffer outputBuffer; + +interface IGetF +{ + float getF(); +} + +struct GetFImpl : IGetF +{ + float getF() { return 1.0; } +}; + +struct GetFImpl2 : IGetF +{ + float getF() { return -1.0; } +}; + +struct GenStruct +{ + T x; + float genGet(U y) + { + return x.getF() + y.getF(); + } +}; + +[numthreads(1, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + uint tid = dispatchThreadID.x; + GenStruct obj1; + GetFImpl2 obj2; + float outVal = obj1.genGet(obj2); + outputBuffer[tid] = int(outVal); +} \ No newline at end of file diff --git a/tests/compute/nested-generics.slang.expected.txt b/tests/compute/nested-generics.slang.expected.txt new file mode 100644 index 000000000..ae25f7400 --- /dev/null +++ b/tests/compute/nested-generics.slang.expected.txt @@ -0,0 +1,4 @@ +0 +0 +0 +0 \ No newline at end of file diff --git a/tests/compute/nested-generics2.slang b/tests/compute/nested-generics2.slang new file mode 100644 index 000000000..6a14c7678 --- /dev/null +++ b/tests/compute/nested-generics2.slang @@ -0,0 +1,43 @@ +//TEST(compute):COMPARE_COMPUTE:-xslang -use-ir +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):dxbinding(0),glbinding(0),out + +// test specialization of nested generic functions + +RWStructuredBuffer outputBuffer; + +interface IBRDF +{ + float getF(); +} + +interface ILight +{ + float illum(B b); +}; + +struct B0 : IBRDF +{ + float getF() { return 1.0; } +}; + +struct L0 : ILight +{ + float illum(B b) { return b.getF(); } +}; + +struct L1 : ILight +{ + L l; + float illum(BXX bxx) { return l.illum(bxx); } +}; + + +[numthreads(4, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + uint tid = dispatchThreadID.x; + L1 light; + B0 b0; + float outVal = light.illum(b0); + outputBuffer[tid] = int(outVal); +} \ No newline at end of file diff --git a/tests/compute/nested-generics2.slang.expected.txt b/tests/compute/nested-generics2.slang.expected.txt new file mode 100644 index 000000000..ef529012e --- /dev/null +++ b/tests/compute/nested-generics2.slang.expected.txt @@ -0,0 +1,4 @@ +1 +1 +1 +1 \ No newline at end of file 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 outputBuffer; + +struct GenStruct +{ + struct SubType + { + T x; + }; + T getVal(SubType v) + { + return v.x; + } +}; + +T test(T val) +{ + GenStruct.SubType sb; + sb.x = val; + GenStruct 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 diff --git a/tests/compute/struct-in-generic.slang.expected.txt b/tests/compute/struct-in-generic.slang.expected.txt new file mode 100644 index 000000000..ae6b9920b --- /dev/null +++ b/tests/compute/struct-in-generic.slang.expected.txt @@ -0,0 +1,4 @@ +0 +3F800000 +40000000 +40400000 -- cgit v1.2.3