diff options
| author | Yong He <yonghe@outlook.com> | 2025-02-20 14:48:51 -0800 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-02-20 14:48:51 -0800 |
| commit | 19867ffca6dca7995c799354081219c9e76f13d1 (patch) | |
| tree | b9153428fc8b7b6f3069931cf816ad374a2e7c52 /source/slang/slang-check-overload.cpp | |
| parent | 9580e311e0cefb0f8e11afc316783a67201654eb (diff) | |
Simplify implicit cast ctors for vector & matrix. (#6408)
* Simplify implicit cast ctors for vector & matrix.
* Fix formatting.
* Fix tests.
* Fix Falcor test.
* Mark __builtin_cast as internal.
Diffstat (limited to 'source/slang/slang-check-overload.cpp')
| -rw-r--r-- | source/slang/slang-check-overload.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/source/slang/slang-check-overload.cpp b/source/slang/slang-check-overload.cpp index b944d2bf4..b75f95f9a 100644 --- a/source/slang/slang-check-overload.cpp +++ b/source/slang/slang-check-overload.cpp @@ -1675,6 +1675,15 @@ int SemanticsVisitor::CompareOverloadCandidates(OverloadCandidate* left, Overloa if (itemDiff) return itemDiff; + // If one candidate is an implicit conversion, and other candidate is not, + // then we should prefer the implicit conversion. + int leftIsImplicitConversion = + left->item.declRef.getDecl()->findModifier<ImplicitConversionModifier>() ? 1 : 0; + int rightIsImplicitConversion = + right->item.declRef.getDecl()->findModifier<ImplicitConversionModifier>() ? 1 : 0; + if (leftIsImplicitConversion != rightIsImplicitConversion) + return rightIsImplicitConversion - leftIsImplicitConversion; + auto specificityDiff = compareOverloadCandidateSpecificity(left->item, right->item); if (specificityDiff) return specificityDiff; |
