From 3ff257816fc8f376d9bee76378a690757f8b5377 Mon Sep 17 00:00:00 2001 From: Sai Praveen Bangaru <31557731+saipraveenb25@users.noreply.github.com> Date: Fri, 17 Jan 2025 17:08:03 -0500 Subject: Fix interface requirement lowering for generic accessors (#6123) --- source/slang/slang-lower-to-ir.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'source') diff --git a/source/slang/slang-lower-to-ir.cpp b/source/slang/slang-lower-to-ir.cpp index 086345719..54540a3f8 100644 --- a/source/slang/slang-lower-to-ir.cpp +++ b/source/slang/slang-lower-to-ir.cpp @@ -8633,6 +8633,9 @@ struct DeclLoweringVisitor : DeclVisitor UInt operandCount = 0; for (auto requirementDecl : decl->members) { + if (as(requirementDecl)) + requirementDecl = getInner(requirementDecl); + if (as(requirementDecl) || as(requirementDecl)) { for (auto accessorDecl : as(requirementDecl)->members) @@ -8782,6 +8785,13 @@ struct DeclLoweringVisitor : DeclVisitor auto requirementKey = getInterfaceRequirementKey(requirementDecl); if (!requirementKey) { + if (auto genericDecl = as(requirementDecl)) + { + // We need to form a declref into the inner decls in case of a generic + // requirement. + requirementDecl = getInner(genericDecl); + } + if (as(requirementDecl) || as(requirementDecl)) { for (auto member : as(requirementDecl)->members) -- cgit v1.2.3