diff options
Diffstat (limited to 'source/slang/slang-reflection-api.cpp')
| -rw-r--r-- | source/slang/slang-reflection-api.cpp | 10 |
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; } |
