diff --git a/source/slang/slang-reflection-api.cpp b/source/slang/slang-reflection-api.cpp index d7f793d051..d235c82703 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( diff --git a/tools/slang-unit-test/unit-test-attribute-reflection.cpp b/tools/slang-unit-test/unit-test-attribute-reflection.cpp index e60eeb2d44..7a47586776 100644 --- a/tools/slang-unit-test/unit-test-attribute-reflection.cpp +++ b/tools/slang-unit-test/unit-test-attribute-reflection.cpp @@ -26,12 +26,13 @@ SLANG_UNIT_TEST(attributeReflection) public struct NormalTextureAttribute { public E Type; + public float x; }; [COM("042BE50B-CB01-4DBB-8367-3A9CDCBE2F49")] interface IInterface { void f(); } - [NormalTexture(E.V1)] + [NormalTexture(E.V1, 6)] struct TS {}; )"; String userSource = userSourceBody; @@ -76,4 +77,8 @@ SLANG_UNIT_TEST(attributeReflection) int value = 0; normalTextureAttribute->getArgumentValueInt(0, &value); SLANG_CHECK(value == 1); + + float fvalue = 0; + normalTextureAttribute->getArgumentValueFloat(1, &fvalue); + SLANG_CHECK(fvalue == 6.0); }