summaryrefslogtreecommitdiff
path: root/source/slang/slang-reflection-api.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang-reflection-api.cpp')
-rw-r--r--source/slang/slang-reflection-api.cpp10
1 files changed, 9 insertions, 1 deletions
diff --git a/source/slang/slang-reflection-api.cpp b/source/slang/slang-reflection-api.cpp
index 5d35c7eef..8ec0979e4 100644
--- a/source/slang/slang-reflection-api.cpp
+++ b/source/slang/slang-reflection-api.cpp
@@ -310,7 +310,7 @@ SLANG_API SlangTypeKind spReflectionType_GetKind(SlangReflectionType* inType)
auto type = convert(inType);
if(!type) return SLANG_TYPE_KIND_NONE;
- // TODO(tfoley: Don't emit the same type more than once...
+ // TODO(tfoley): Don't emit the same type more than once...
if (const auto basicType = as<BasicExpressionType>(type))
{
@@ -360,6 +360,10 @@ SLANG_API SlangTypeKind spReflectionType_GetKind(SlangReflectionType* inType)
{
return SLANG_TYPE_KIND_FEEDBACK;
}
+ else if (const auto ptrType = as<PtrType>(type))
+ {
+ return SLANG_TYPE_KIND_POINTER;
+ }
// TODO: need a better way to handle this stuff...
#define CASE(TYPE) \
else if(as<TYPE>(type)) do { \
@@ -993,6 +997,10 @@ SLANG_API SlangReflectionTypeLayout* spReflectionTypeLayout_GetElementTypeLayout
{
return convert(matrixTypeLayout->elementTypeLayout);
}
+ else if (auto ptrTypeLayout = as<PointerTypeLayout>(typeLayout))
+ {
+ return convert(ptrTypeLayout->valueTypeLayout.Ptr());
+ }
return nullptr;
}