From 88e221bad60ce20087fe2f8a85d506be36a6e6ca Mon Sep 17 00:00:00 2001 From: Yong He Date: Mon, 30 Dec 2024 23:38:34 -0800 Subject: Fix requirement candidate lookup to prefer decls in the same paraent as the inheritance decl. (#5965) --- .../interfaces/overloaded-associatedtype.slang | 43 ++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 tests/language-feature/interfaces/overloaded-associatedtype.slang (limited to 'tests/language-feature') diff --git a/tests/language-feature/interfaces/overloaded-associatedtype.slang b/tests/language-feature/interfaces/overloaded-associatedtype.slang new file mode 100644 index 000000000..4630c76a6 --- /dev/null +++ b/tests/language-feature/interfaces/overloaded-associatedtype.slang @@ -0,0 +1,43 @@ +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -output-using-type + +interface IFoo { + associatedtype Output : IBar; + func foo(other: T) -> Output; +} + +interface IBar { int getId(); } + +struct Ant:IBar { int getId() { return 0; } }; +struct Bat:IBar { int getId() { return 1; } }; +struct Cat:IBar { int getId() { return 2; } }; +struct Dog:IBar { int getId() { return 3; } }; +struct Ewe:IBar { int getId() { return 4; } }; +struct Fox:IBar { int getId() { return 5; } }; +struct Gnu:IBar { int getId() { return 6; } }; + +extension Ant: IFoo { + typedef Cat Output; + func foo(other: Bat) -> Cat { return Cat(); } +} +extension Ant: IFoo { + typedef Ewe Output; + func foo(other: Dog) -> Ewe { return Ewe(); } +} +extension Ant: IFoo { + typedef Gnu Output; + func foo(other: Fox) -> Gnu { return Gnu(); } +} + +int test>(T v) { + return v.foo(Fox()).getId(); +} + +//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=output +RWStructuredBuffer output; + +[numthreads(1,1,1)] +void computeMain() { + Ant a; + // CHECK: 6 + output[0] = test(a); +} \ No newline at end of file -- cgit v1.2.3