From 6a23949f07f4eba38086b656e7073ce3bf8cd2fe Mon Sep 17 00:00:00 2001 From: Yong He Date: Fri, 13 Jun 2025 22:13:00 -0700 Subject: Allow interface methods to have default implementations. (#7439) --- .../default-method-generic-interface.slang | 55 ++++++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 tests/language-feature/interfaces/default-method-generic-interface.slang (limited to 'tests/language-feature/interfaces/default-method-generic-interface.slang') diff --git a/tests/language-feature/interfaces/default-method-generic-interface.slang b/tests/language-feature/interfaces/default-method-generic-interface.slang new file mode 100644 index 000000000..fb32b2001 --- /dev/null +++ b/tests/language-feature/interfaces/default-method-generic-interface.slang @@ -0,0 +1,55 @@ +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -shaderobj -output-using-type + +// Test that a generic interface method in a generic interface +// can have a body providing default implementation. + +interface IFoo +{ + int getVal(); + int getGreaterVal() + { + return getVal() + x + v; + } +} + +struct Impl : IFoo<2> +{ + int getVal() + { + return 42; + } + + // Using the default implementation for getGreaterVal. +} + +struct Impl2 : IFoo<2> +{ + int getVal() + { + return 42; + } + + // overriding default implementation. + int getGreaterVal() + { + return 100 + x; + } +} + +int test>(T v) { return v.getGreaterVal<1>(); } + +//TEST_INPUT: set resultBuffer = out ubuffer(data=[0 0 0 0], stride=4) +RWStructuredBuffer resultBuffer; + +[numthreads(1,1,1)] +void computeMain() +{ + Impl impl = {}; + int result = test(impl); + resultBuffer[0] = result; + // CHECK: 45 + + Impl2 impl2 = {}; + resultBuffer[1] = test(impl2); + // CHECK: 101 +} \ No newline at end of file -- cgit v1.2.3