From c6b9a91253bce6d450efc281b3f86617b3eef633 Mon Sep 17 00:00:00 2001 From: kaizhangNV <149626564+kaizhangNV@users.noreply.github.com> Date: Tue, 23 Apr 2024 18:39:15 -0700 Subject: Do not diagnose error when a symbols is defined as 'extern' and 'export' (#4010) Fix the issue (#3999). For a function is defined as extern and export at the same time, don't report error, we can use the 'export' function to overload the 'extern' function. --- source/slang/slang-check-decl.cpp | 7 +++++++ source/slang/slang-check-overload.cpp | 14 ++++++++++++++ 2 files changed, 21 insertions(+) (limited to 'source') diff --git a/source/slang/slang-check-decl.cpp b/source/slang/slang-check-decl.cpp index 17551912d..cb68dced9 100644 --- a/source/slang/slang-check-decl.cpp +++ b/source/slang/slang-check-decl.cpp @@ -6944,6 +6944,13 @@ namespace Slang if (!doFunctionSignaturesMatch(newDeclRef, oldDeclRef)) return SLANG_OK; + // If the declatation is declared by 'extern', and new definition is with 'export', then + // we should let overload resolution to handle it. + if (oldDecl->hasModifier() && newDecl->hasModifier()) + { + return SLANG_OK; + } + // If we get this far, then we've got two declarations in the same // scope, with the same name and signature, so they appear // to be redeclarations. diff --git a/source/slang/slang-check-overload.cpp b/source/slang/slang-check-overload.cpp index 7a38b08c0..6180ccda8 100644 --- a/source/slang/slang-check-overload.cpp +++ b/source/slang/slang-check-overload.cpp @@ -1141,6 +1141,15 @@ namespace Slang return 0; } + int getExportRank(DeclRef left, DeclRef right) + { + if (left.getDecl() && left.getDecl()->hasModifier()) + { + return (right.getDecl() && right.getDecl()->hasModifier()) ? -1 : 0; + } + return 0; + } + int SemanticsVisitor::CompareOverloadCandidates( OverloadCandidate* left, OverloadCandidate* right) @@ -1214,6 +1223,11 @@ namespace Slang if(specificityDiff) return specificityDiff; + // `export` function is more flavored than `extern` function. But other modifiers are not considered. + auto externExportDiff = getExportRank(left->item.declRef, right->item.declRef); + if (externExportDiff) + return externExportDiff; + // If we reach here, we will attempt to use overload rank to break the ties. auto overloadRankDiff = getOverloadRank(right->item.declRef) - getOverloadRank(left->item.declRef); if (overloadRankDiff) -- cgit v1.2.3