summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-syntax.cpp
diff options
context:
space:
mode:
authorjsmall-nvidia <jsmall@nvidia.com>2020-04-08 10:56:00 -0400
committerGitHub <noreply@github.com>2020-04-08 10:56:00 -0400
commita9214f34358b2fc0bf61ef90e3719a13b180b423 (patch)
tree115b49d976f871a9f529436e201cf2f4a1a59401 /source/slang/slang-syntax.cpp
parentba232e44cbb016a4e7c111b42458394027369c5e (diff)
Remove static struct members from layout and reflection (#1310)
* * Added MemberFilterStyle - controls action of FilteredMemberList and FilteredMemberRefList * Splt out template implementations * Use more standard method names dofr FilteredMemberRefList * Added reflect-static.slang test * Added isNotEmpty/isEmpty to filtered lists * Added ability to index into filtered list (so not require building of array) * Default MemberFilterStyle to All. * Remove explicit MemberFilterStyle::All
Diffstat (limited to 'source/slang/slang-syntax.cpp')
-rw-r--r--source/slang/slang-syntax.cpp146
1 files changed, 144 insertions, 2 deletions
diff --git a/source/slang/slang-syntax.cpp b/source/slang/slang-syntax.cpp
index 1dcaafec5..334273870 100644
--- a/source/slang/slang-syntax.cpp
+++ b/source/slang/slang-syntax.cpp
@@ -184,12 +184,154 @@ static bool _checkSubClassRange()
return SLANG_OK;
}
+ // Free functions
-void Type::accept(IValVisitor* visitor, void* extra)
+const RefPtr<Decl>* adjustFilterCursorImpl(const SyntaxClassBase::ClassInfo& clsInfo, MemberFilterStyle filterStyle, const RefPtr<Decl>* ptr, const RefPtr<Decl>* end)
{
- accept((ITypeVisitor*)visitor, extra);
+ switch (filterStyle)
+ {
+ default:
+ case MemberFilterStyle::All:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ if (decl->getClassInfo().isSubClassOf(clsInfo))
+ {
+ return ptr;
+ }
+ }
+ break;
+ }
+ case MemberFilterStyle::Instance:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ if (decl->getClassInfo().isSubClassOf(clsInfo) && !decl->HasModifier<HLSLStaticModifier>())
+ {
+ return ptr;
+ }
+ }
+ break;
+ }
+ case MemberFilterStyle::Static:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ if (decl->getClassInfo().isSubClassOf(clsInfo) && decl->HasModifier<HLSLStaticModifier>())
+ {
+ return ptr;
+ }
+ }
+ break;
+ }
+ }
+ return end;
+}
+
+const RefPtr<Decl>* getFilterCursorByIndexImpl(const SyntaxClassBase::ClassInfo& clsInfo, MemberFilterStyle filterStyle, const RefPtr<Decl>* ptr, const RefPtr<Decl>* end, Index index)
+{
+ switch (filterStyle)
+ {
+ default:
+ case MemberFilterStyle::All:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ if (decl->getClassInfo().isSubClassOf(clsInfo))
+ {
+ if (index <= 0)
+ {
+ return ptr;
+ }
+ index--;
+ }
+ }
+ break;
+ }
+ case MemberFilterStyle::Instance:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ if (decl->getClassInfo().isSubClassOf(clsInfo) && !decl->HasModifier<HLSLStaticModifier>())
+ {
+ if (index <= 0)
+ {
+ return ptr;
+ }
+ index--;
+ }
+ }
+ break;
+ }
+ case MemberFilterStyle::Static:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ if (decl->getClassInfo().isSubClassOf(clsInfo) && decl->HasModifier<HLSLStaticModifier>())
+ {
+ if (index <= 0)
+ {
+ return ptr;
+ }
+ index--;
+ }
+ }
+ break;
+ }
+ }
+ return nullptr;
}
+Index getFilterCountImpl(const SyntaxClassBase::ClassInfo& clsInfo, MemberFilterStyle filterStyle, const RefPtr<Decl>* ptr, const RefPtr<Decl>* end)
+{
+ Index count = 0;
+ switch (filterStyle)
+ {
+ default:
+ case MemberFilterStyle::All:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ count += Index(decl->getClassInfo().isSubClassOf(clsInfo));
+ }
+ break;
+ }
+ case MemberFilterStyle::Instance:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ count += Index(decl->getClassInfo().isSubClassOf(clsInfo)&& !decl->HasModifier<HLSLStaticModifier>());
+ }
+ break;
+ }
+ case MemberFilterStyle::Static:
+ {
+ for (; ptr != end; ptr++)
+ {
+ Decl* decl = *ptr;
+ count += Index(decl->getClassInfo().isSubClassOf(clsInfo) && decl->HasModifier<HLSLStaticModifier>());
+ }
+ break;
+ }
+ }
+ return count;
+}
+
+ // Type
+
+ void Type::accept(IValVisitor* visitor, void* extra)
+ {
+ accept((ITypeVisitor*)visitor, extra);
+ }
+
// TypeExp
bool TypeExp::Equals(Type* other)