From dd3d80e61b316390a468a142de2be2fb85b73d0d Mon Sep 17 00:00:00 2001 From: Sai Praveen Bangaru <31557731+saipraveenb25@users.noreply.github.com> Date: Thu, 19 Sep 2024 16:27:50 -0400 Subject: Allow lookups of overloaded methods. (#5110) * Allow lookups of overloaded methods. * Update slang-reflection-api.cpp * Update slang.cpp --------- Co-authored-by: Yong He --- source/slang/slang.cpp | 61 ++++++++++++++++++++++++-------------------------- 1 file changed, 29 insertions(+), 32 deletions(-) (limited to 'source/slang/slang.cpp') diff --git a/source/slang/slang.cpp b/source/slang/slang.cpp index 6c152cddd..dc5f9a755 100644 --- a/source/slang/slang.cpp +++ b/source/slang/slang.cpp @@ -1370,7 +1370,7 @@ DeclRef getGenericParentDeclRef( } DeclRef Linkage::specializeWithArgTypes( - DeclRef funcDeclRef, + Expr* funcExpr, List argTypes, DiagnosticSink* sink) { @@ -1378,6 +1378,16 @@ DeclRef Linkage::specializeWithArgTypes( visitor = visitor.withSink(sink); ASTBuilder* astBuilder = getASTBuilder(); + + if (auto declRefFuncExpr = as(funcExpr)) + { + auto genericDeclRefExpr = astBuilder->create(); + genericDeclRefExpr->declRef = getGenericParentDeclRef( + getASTBuilder(), + &visitor, + declRefFuncExpr->declRef); + funcExpr = genericDeclRefExpr; + } List argExprs; for (SlangInt aa = 0; aa < argTypes.getCount(); ++aa) @@ -1394,10 +1404,7 @@ DeclRef Linkage::specializeWithArgTypes( // Construct invoke expr. auto invokeExpr = astBuilder->create(); - auto declRefExpr = astBuilder->create(); - - declRefExpr->declRef = getGenericParentDeclRef(getASTBuilder(), &visitor, funcDeclRef); - invokeExpr->functionExpr = declRefExpr; + invokeExpr->functionExpr = funcExpr; invokeExpr->arguments = argExprs; auto checkedInvokeExpr = visitor.CheckInvokeExprWithCheckedOperands(invokeExpr); @@ -2331,14 +2338,14 @@ Type* ComponentType::getTypeFromString( return type; } -DeclRef ComponentType::findDeclFromString( +Expr* ComponentType::findDeclFromString( String const& name, DiagnosticSink* sink) { // If we've looked up this type name before, // then we can re-use it. // - DeclRef result; + Expr* result = nullptr; if (m_decls.tryGetValue(name, result)) return result; @@ -2369,34 +2376,26 @@ DeclRef ComponentType::findDeclFromString( SemanticsVisitor visitor(context); - auto checkedExpr = visitor.CheckExpr(expr); - if (auto declRefExpr = as(checkedExpr)) - { - result = declRefExpr->declRef; - } - else if (auto overloadedExpr = as(checkedExpr)) + auto checkedExpr = visitor.CheckTerm(expr); + + if (as(checkedExpr) || as(checkedExpr)) { - sink->diagnose(SourceLoc(), Diagnostics::ambiguousReference, name); - for (auto candidate : overloadedExpr->lookupResult2) - { - sink->diagnose(candidate.declRef.getDecl(), Diagnostics::overloadCandidate, candidate.declRef); - } + result = checkedExpr; } + m_decls[name] = result; return result; } -DeclRef ComponentType::findDeclFromStringInType( +Expr* ComponentType::findDeclFromStringInType( Type* type, String const& name, LookupMask mask, DiagnosticSink* sink) { - DeclRef result; - // Only look up in the type if it is a DeclRefType if (!as(type)) - return DeclRef(); + return nullptr; // TODO(JS): For now just used the linkages ASTBuilder to keep on scope // @@ -2433,7 +2432,7 @@ DeclRef ComponentType::findDeclFromStringInType( } if (!as(expr)) - return result; + return nullptr; auto rs = astBuilder->create(); auto typeExpr = astBuilder->create(); @@ -2453,20 +2452,18 @@ DeclRef ComponentType::findDeclFromStringInType( auto checkedTerm = visitor.CheckTerm(expr); auto resolvedTerm = visitor.maybeResolveOverloadedExpr(checkedTerm, mask, sink); + - if (auto declRefExpr = as(resolvedTerm)) + if (auto overloadedExpr = as(resolvedTerm)) { - result = declRefExpr->declRef; + return overloadedExpr; } - - if (auto genericDeclRef = result.as()) - { - result = createDefaultSubstitutionsIfNeeded( - astBuilder, &visitor, DeclRef(genericDeclRef.getDecl()->inner)); - result = substituteDeclRef(SubstitutionSet(genericDeclRef), astBuilder, result); + if (auto declRefExpr = as(resolvedTerm)) + { + return declRefExpr; } - return result; + return nullptr; } bool ComponentType::isSubType(Type* subType, Type* superType) -- cgit v1.2.3