summaryrefslogtreecommitdiff
path: root/source/slang/slang-check-decl.cpp
diff options
context:
space:
mode:
authorCopilot <198982749+Copilot@users.noreply.github.com>2025-07-18 23:01:55 +0000
committerGitHub <noreply@github.com>2025-07-18 23:01:55 +0000
commit4d514f792fc590e28579a184be8890613d0fdf9e (patch)
tree5d069f7896ee05a51a3745bc34b3c4e1893efcfc /source/slang/slang-check-decl.cpp
parent3df9fe8a8a1aa01db2651eacd1d8bec50d0ee90c (diff)
Fix enum array indexing by adding implicit conversion support (#7815)
* Initial plan * Fix enum array indexing by adding implicit conversion support Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> * Update enum array indexing test to support GPU backends Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com> --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: csyonghe <2652293+csyonghe@users.noreply.github.com>
Diffstat (limited to 'source/slang/slang-check-decl.cpp')
-rw-r--r--source/slang/slang-check-decl.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/source/slang/slang-check-decl.cpp b/source/slang/slang-check-decl.cpp
index 1dc230dae..806912abe 100644
--- a/source/slang/slang-check-decl.cpp
+++ b/source/slang/slang-check-decl.cpp
@@ -8485,6 +8485,16 @@ bool SemanticsVisitor::isScalarIntegerType(Type* type)
return isIntegerBaseType(baseType) || baseType == BaseType::Bool;
}
+Type* SemanticsVisitor::getMatchingIntType(Type* type)
+{
+ if (isScalarIntegerType(type))
+ return type;
+ if (auto enumTypeDecl = isDeclRefTypeOf<EnumDecl>(type))
+ if (enumTypeDecl.getDecl()->tagType)
+ return getMatchingIntType(enumTypeDecl.getDecl()->tagType);
+ return m_astBuilder->getIntType();
+}
+
bool SemanticsVisitor::isHalfType(Type* type)
{
auto basicType = as<BasicExpressionType>(type);