From 2b0760086bdf84dbd43c320556d7949d9d405dee Mon Sep 17 00:00:00 2001 From: Yong He Date: Fri, 17 Jan 2025 14:02:05 -0800 Subject: [PATCH] Fix. --- source/slang/slang-parser.cpp | 5 ++++ .../generics/generic-subscript.slang | 24 +++++++++++++++++++ 2 files changed, 29 insertions(+) create mode 100644 tests/language-feature/generics/generic-subscript.slang diff --git a/source/slang/slang-parser.cpp b/source/slang/slang-parser.cpp index ac0ebdd0b1..98cfd121c0 100644 --- a/source/slang/slang-parser.cpp +++ b/source/slang/slang-parser.cpp @@ -3954,6 +3954,11 @@ static NodeBase* parseSubscriptDecl(Parser* parser, void* /*userData*/) decl->returnType.exp = parser->astBuilder->create(); } + auto funcScope = parser->currentScope; + parser->PopScope(); + maybeParseGenericConstraints(parser, genericParent); + parser->PushScope(funcScope); + parseStorageDeclBody(parser, decl); parser->PopScope(); diff --git a/tests/language-feature/generics/generic-subscript.slang b/tests/language-feature/generics/generic-subscript.slang new file mode 100644 index 0000000000..87eec3045c --- /dev/null +++ b/tests/language-feature/generics/generic-subscript.slang @@ -0,0 +1,24 @@ +//TEST:COMPARE_COMPUTE(filecheck-buffer=CHECK): -output-using-type + +//TEST_INPUT: set output = out ubuffer(data=[0 0 0 0], stride=4) +RWStructuredBuffer output; + +struct Tx +{ + float x; + __subscript(I index) -> float + where I:IInteger + { + get { return x + index.toInt(); } + set { x = newValue;} + } +} + +[numthreads(1,1,1)] +void computeMain() +{ + Tx obj; + obj[0] = 3.0; + // CHECK: 5.0 + output[0] = obj[2]; +} \ No newline at end of file