From 134f8ccc930a8da28808c2e288344c21c67a577e Mon Sep 17 00:00:00 2001 From: Yong He Date: Wed, 31 Jul 2024 10:03:39 -0700 Subject: Fix IR lowering for generic interface types. (#4761) * Fix IR lowering for generic interface types. * Fix. * Fix. --- .../interfaces/generic-interface-conformance.slang | 31 ++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 tests/language-feature/interfaces/generic-interface-conformance.slang (limited to 'tests/language-feature/interfaces') diff --git a/tests/language-feature/interfaces/generic-interface-conformance.slang b/tests/language-feature/interfaces/generic-interface-conformance.slang new file mode 100644 index 000000000..9e0510125 --- /dev/null +++ b/tests/language-feature/interfaces/generic-interface-conformance.slang @@ -0,0 +1,31 @@ +// Test that we allow type conformances whose base interface is generic. + +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHECK):-dx11 -compute -output-using-type +//TEST(compute):COMPARE_COMPUTE_EX(filecheck-buffer=CHECK):-vk -compute -output-using-type + +public interface ITestInterface { + Real sample(); +} + +struct TestInterfaceImpl : ITestInterface { + Real sample() { + return x; + } + Real x; +} + +//TEST_INPUT: set data = new StructuredBuffer >[new TestInterfaceImpl{1.0}]; +StructuredBuffer> data; + +//TEST_INPUT: set outputBuffer = out ubuffer(data=[0 0 0 0], stride=4); +RWStructuredBuffer outputBuffer; + +//TEST_INPUT: type_conformance TestInterfaceImpl:ITestInterface = 3 + +[numthreads(1, 1, 1)] +void computeMain() +{ + let obj = data[0]; + // CHECK: 1 + outputBuffer[0] = int(obj.sample()); +} \ No newline at end of file -- cgit v1.2.3