diff options
| author | jsmall-nvidia <jsmall@nvidia.com> | 2020-04-08 10:56:00 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-04-08 10:56:00 -0400 |
| commit | a9214f34358b2fc0bf61ef90e3719a13b180b423 (patch) | |
| tree | 115b49d976f871a9f529436e201cf2f4a1a59401 /source/slang/slang-syntax.cpp | |
| parent | ba232e44cbb016a4e7c111b42458394027369c5e (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.cpp | 146 |
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) |
