From c198eaba351850fcb3d82c2f5117efc0e2e2bf1e Mon Sep 17 00:00:00 2001 From: Yong He Date: Tue, 5 Feb 2019 14:20:14 -0800 Subject: Allow generics to close with >> --- tests/compute/generic-closer.slang | 41 +++++++++++++++++++++++++ tests/compute/generic-closer.slang.expected.txt | 4 +++ 2 files changed, 45 insertions(+) create mode 100644 tests/compute/generic-closer.slang create mode 100644 tests/compute/generic-closer.slang.expected.txt (limited to 'tests/compute') diff --git a/tests/compute/generic-closer.slang b/tests/compute/generic-closer.slang new file mode 100644 index 000000000..f3bb643de --- /dev/null +++ b/tests/compute/generic-closer.slang @@ -0,0 +1,41 @@ +//TEST(compute):COMPARE_COMPUTE_EX:-slang -compute +//TEST(compute):COMPARE_COMPUTE_EX:-slang -compute -dx12 +//TEST(compute, vulkan):COMPARE_COMPUTE_EX:-vk -compute + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):dxbinding(0),glbinding(0),out + +interface IGetter +{ + int get(); +} +struct Gen0 : IGetter +{ + int get() { return 1; } +}; +struct Gen1 : IGetter +{ + TGetter g; + int get() { return g.get(); } +}; + +RWStructuredBuffer outputBuffer; +void writeArray(inout float3 a[4]) +{ + a[0] = float3(1, 1, 1); + a[1] = float3(1, 1, 1); + a[2] = float3(1, 1, 1); + a[3] = float3(1, 1, 1); +} + +[numthreads(4, 1, 1)] +void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID) +{ + Gen1>> g; + Gen1>>> g2; + Gen1> g3; + + int a = 0; + int b = 5; + if (a< b && b > a) + outputBuffer[dispatchThreadID.x] = (g.get() >> 1) + g2.get() + g3.get(); +} \ No newline at end of file diff --git a/tests/compute/generic-closer.slang.expected.txt b/tests/compute/generic-closer.slang.expected.txt new file mode 100644 index 000000000..01dd2b944 --- /dev/null +++ b/tests/compute/generic-closer.slang.expected.txt @@ -0,0 +1,4 @@ +2 +2 +2 +2 \ No newline at end of file -- cgit v1.2.3