summaryrefslogtreecommitdiffstats
path: root/source
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2024-12-17 08:31:37 -0800
committerGitHub <noreply@github.com>2024-12-18 00:31:37 +0800
commitd61bba8cac1aad3c559cea73fa56d593777ad2d7 (patch)
treeb8656d10b3dbedda0cb57d3a661b6c6abcb390a1 /source
parent9c9e1f701242b59dead94426a25f2ad5d3bcf66d (diff)
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>
Diffstat (limited to 'source')
-rw-r--r--source/slang/slang-reflection-api.cpp10
1 files changed, 10 insertions, 0 deletions
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<ImplicitCastExpr>(userAttr->args[index]))
+ {
+ auto base = implicitCastExpr->arguments[0];
+ if (auto intLit = as<IntegerLiteralExpr>(base))
+ {
+ *rs = (float)intLit->value;
+ return 0;
+ }
+ }
return SLANG_E_INVALID_ARG;
}
SLANG_API const char* spReflectionUserAttribute_GetArgumentValueString(