summaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
Diffstat (limited to 'tools')
-rw-r--r--tools/slang-reflection-test/slang-reflection-test-main.cpp32
1 files changed, 28 insertions, 4 deletions
diff --git a/tools/slang-reflection-test/slang-reflection-test-main.cpp b/tools/slang-reflection-test/slang-reflection-test-main.cpp
index ba6096f20..655b4e41d 100644
--- a/tools/slang-reflection-test/slang-reflection-test-main.cpp
+++ b/tools/slang-reflection-test/slang-reflection-test-main.cpp
@@ -539,6 +539,11 @@ static void emitReflectionResourceTypeBaseInfoJSON(
comma(writer);
write(writer, "\"multisample\": true");
}
+ if (shape & SLANG_TEXTURE_FEEDBACK_FLAG)
+ {
+ comma(writer);
+ write(writer, "\"feedback\": true");
+ }
if( access != SLANG_RESOURCE_ACCESS_READ )
{
@@ -553,7 +558,7 @@ static void emitReflectionResourceTypeBaseInfoJSON(
case SLANG_RESOURCE_ACCESS_READ:
break;
-
+ case SLANG_RESOURCE_ACCESS_WRITE: write(writer, "write"); break;
case SLANG_RESOURCE_ACCESS_READ_WRITE: write(writer, "readWrite"); break;
case SLANG_RESOURCE_ACCESS_RASTER_ORDERED: write(writer, "rasterOrdered"); break;
case SLANG_RESOURCE_ACCESS_APPEND: write(writer, "append"); break;
@@ -730,6 +735,12 @@ static void emitReflectionTypeInfoJSON(
comma(writer);
emitReflectionNameInfoJSON(writer, type->getName());
break;
+ case slang::TypeReflection::Kind::Feedback:
+ comma(writer);
+ write(writer, "\"kind\": \"Feedback\"");
+ comma(writer);
+ emitReflectionNameInfoJSON(writer, type->getName());
+ break;
default:
assert(!"unhandled case");
break;
@@ -909,9 +920,11 @@ static void emitReflectionTypeLayoutInfoJSON(
// the relevant cases here.
//
auto type = typeLayout->getType();
- auto shape = type->getResourceShape();
+ auto shape = type->getResourceShape();
- if( (shape & SLANG_RESOURCE_BASE_SHAPE_MASK) == SLANG_STRUCTURED_BUFFER )
+ const auto baseType = shape & SLANG_RESOURCE_BASE_SHAPE_MASK;
+
+ if (baseType == SLANG_STRUCTURED_BUFFER)
{
emitReflectionResourceTypeBaseInfoJSON(writer, type);
@@ -924,9 +937,20 @@ static void emitReflectionTypeLayoutInfoJSON(
resultTypeLayout);
}
}
+ else if (shape & SLANG_TEXTURE_FEEDBACK_FLAG)
+ {
+ emitReflectionResourceTypeBaseInfoJSON(writer, type);
+
+ if (auto resultType = typeLayout->getResourceResultType())
+ {
+ comma(writer);
+ write(writer, "\"resultType\": ");
+ emitReflectionTypeJSON(writer, resultType);
+ }
+ }
else
{
- emitReflectionTypeInfoJSON(writer, typeLayout->getType());
+ emitReflectionTypeInfoJSON(writer, type);
}
}
break;