From 2ae194d51e15c064c3d905e628f7335de7504e32 Mon Sep 17 00:00:00 2001 From: Yong He Date: Wed, 29 Jan 2025 23:11:06 -0800 Subject: Fix ConstantIntVal::toText when the val is a enum. (#6224) * Fix ConstantIntVal::toText when the val is a enum. * Fix comment. --- source/slang/slang-ast-val.cpp | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'source/slang/slang-ast-val.cpp') diff --git a/source/slang/slang-ast-val.cpp b/source/slang/slang-ast-val.cpp index 98135ef16..9bcfd21bc 100644 --- a/source/slang/slang-ast-val.cpp +++ b/source/slang/slang-ast-val.cpp @@ -149,6 +149,30 @@ void Val::_toTextOverride(StringBuilder& out) void ConstantIntVal::_toTextOverride(StringBuilder& out) { + if (auto enumTypeDecl = isDeclRefTypeOf(getType())) + { + // If this is an enum type, then we want to print the name of the + // corresponding enum case, instead of the raw integer value, if possible. + // + // We will look up the enum case that corresponds to the value, and + // print its name if we can find one. + // + for (auto enumCase : enumTypeDecl.getDecl()->getMembersOfType()) + { + if (auto constVal = as(enumCase->tagVal)) + { + if (constVal->getValue() == getValue()) + { + out << DeclRef(enumCase); + return; + } + } + } + + // Fallback to explicit cast to the enum type. + out << getType() << "(" << getValue() << ")"; + return; + } out << getValue(); } -- cgit v1.2.3