diff options
| author | Yong He <yonghe@outlook.com> | 2024-08-20 20:51:57 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-08-20 20:51:57 -0700 |
| commit | f9f6a28df40f418ddd0c8ff3b9cacccdb085e202 (patch) | |
| tree | a6bafa63cee4f9bbcfe496de54af6e5727bb021e /tests/language-feature/generics/dependent-generic-2.slang | |
| parent | 03e1e17745920c8e3a7b6f4e3b1e64062589604a (diff) | |
Support dependent generic constraints. (#4870)
* Support dependent generic constraints.
* Fix warning.
* Update comment.
* Fix.
* Add a test case to verify fix of #3804.
* Address review.
Diffstat (limited to 'tests/language-feature/generics/dependent-generic-2.slang')
| -rw-r--r-- | tests/language-feature/generics/dependent-generic-2.slang | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/tests/language-feature/generics/dependent-generic-2.slang b/tests/language-feature/generics/dependent-generic-2.slang new file mode 100644 index 000000000..909669827 --- /dev/null +++ b/tests/language-feature/generics/dependent-generic-2.slang @@ -0,0 +1,49 @@ +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -shaderobj -output-using-type +//TEST(compute):COMPARE_COMPUTE(filecheck-buffer=CHECK): -vk -shaderobj -output-using-type + +// Test that we can infer a generic type parameter from the base type of a dependent generic argument. + +interface IFoo : IDefaultInitializable +{ + int get(); +} + +struct Foo : IFoo +{ + int get() + { + return 1; + } +} + +interface IBar<T : IFoo> +{ + int getVal(); +} + +struct Bar<T : IFoo> : IBar<T> +{ + int getVal() + { + T t = T(); + return t.get(); + } +} + +int test<T:IFoo, B : IBar<T>>(B b) +{ + return b.getVal(); +} + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer +RWStructuredBuffer<int> outputBuffer; + +[numthreads(1, 1, 1)] +void computeMain(int3 dispatchThreadID : SV_DispatchThreadID) +{ + Bar<Foo> obj2; + let result = test(obj2); + + // CHECK: 1 + outputBuffer[0] = result; +} |
