From d61bba8cac1aad3c559cea73fa56d593777ad2d7 Mon Sep 17 00:00:00 2001 From: Yong He Date: Tue, 17 Dec 2024 08:31:37 -0800 Subject: Fix `getArgumentValueFloat` when arg is int. (#5888) * Fix `getArgumentValueFloat` when arg is int. * format code --------- Co-authored-by: slangbot <186143334+slangbot@users.noreply.github.com> --- source/slang/slang-reflection-api.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'source') diff --git a/source/slang/slang-reflection-api.cpp b/source/slang/slang-reflection-api.cpp index d7f793d05..d235c8270 100644 --- a/source/slang/slang-reflection-api.cpp +++ b/source/slang/slang-reflection-api.cpp @@ -1,6 +1,7 @@ // slang-reflection-api.cpp #include "../core/slang-basic.h" +#include "slang-check-impl.h" #include "slang-check.h" #include "slang-compiler.h" #include "slang-syntax.h" @@ -353,6 +354,15 @@ SLANG_API SlangResult spReflectionUserAttribute_GetArgumentValueFloat( *rs = (float)cexpr->value; return 0; } + else if (auto implicitCastExpr = as(userAttr->args[index])) + { + auto base = implicitCastExpr->arguments[0]; + if (auto intLit = as(base)) + { + *rs = (float)intLit->value; + return 0; + } + } return SLANG_E_INVALID_ARG; } SLANG_API const char* spReflectionUserAttribute_GetArgumentValueString( -- cgit v1.2.3