From f8bf75cf1ae0aeee155996a917c2925bc500f3e2 Mon Sep 17 00:00:00 2001 From: Yong He Date: Wed, 25 Oct 2023 07:45:23 -0700 Subject: Support generic interfaces. (#3278) * Initial support for generic interfaces. * Cleanup. * Add generic syntax for interfaces. --------- Co-authored-by: Yong He --- .../generics/generic-interface-1.slang | 37 ++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 tests/language-feature/generics/generic-interface-1.slang (limited to 'tests/language-feature/generics') diff --git a/tests/language-feature/generics/generic-interface-1.slang b/tests/language-feature/generics/generic-interface-1.slang new file mode 100644 index 000000000..217e7f06f --- /dev/null +++ b/tests/language-feature/generics/generic-interface-1.slang @@ -0,0 +1,37 @@ +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -shaderobj -output-using-type +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -vk -shaderobj -output-using-type + +interface IEqlTestable +{ + bool testEql(T v1); +} + +bool test(IEqlTestable v0, T v1) +{ + return v0.testEql(v1); +} + +struct MyType : IEqlTestable +{ + int val; + bool testEql(MyType v1) + { + return val == v1.val; + } +} + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +[numthreads(2, 1, 1)] +void computeMain(int3 dispatchThreadID : SV_DispatchThreadID) +{ + int tid = dispatchThreadID.x; + MyType obj1, obj2; + obj1.val = tid; + obj2.val = 1; + let result = test(obj1, obj2); + outputBuffer[tid] = result ? 1 : 0; + // CHECK: 0 + // CHECK: 1 +} -- cgit v1.2.3