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. --- .../static-const-in-generic-interface.slang | 33 ++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 tests/language-feature/constants/static-const-in-generic-interface.slang (limited to 'tests/language-feature/constants') diff --git a/tests/language-feature/constants/static-const-in-generic-interface.slang b/tests/language-feature/constants/static-const-in-generic-interface.slang new file mode 100644 index 000000000..87d8e3be8 --- /dev/null +++ b/tests/language-feature/constants/static-const-in-generic-interface.slang @@ -0,0 +1,33 @@ +// static-const-in-generic-interface.slang + +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -shaderobj + +// Test that `static const` variable declarations inside of +// a generic `interface` type correctly translate to interface requirements. + +interface ITest +{ + static const T kUserDefinedValue; +} + +struct Impl : ITest +{ + static const int kUserDefinedValue = 4; +} + +struct EnsureCompileTimeEval +{ + static T getValue>() { return U.kUserDefinedValue; } +} + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer outputBuffer; + +[numthreads(1, 1, 1)] +void computeMain(int3 dispatchThreadID : SV_DispatchThreadID) +{ + static const int result = EnsureCompileTimeEval.getValue(); + int outVal = result; + // CHECK: 4 + outputBuffer[0] = outVal; +} -- cgit v1.2.3