summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-check-decl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang-check-decl.cpp')
-rw-r--r--source/slang/slang-check-decl.cpp63
1 files changed, 56 insertions, 7 deletions
diff --git a/source/slang/slang-check-decl.cpp b/source/slang/slang-check-decl.cpp
index f0cd32e74..1a70e25d7 100644
--- a/source/slang/slang-check-decl.cpp
+++ b/source/slang/slang-check-decl.cpp
@@ -3494,14 +3494,8 @@ struct SemanticsDeclDifferentialConformanceVisitor
}
};
-/// Recursively register any builtin declarations that need to be attached to the `session`.
-///
-/// This function should only be needed for declarations in the core module.
-///
-static void _registerBuiltinDeclsRec(Session* session, Decl* decl)
+void registerBuiltinDecl(SharedASTBuilder* sharedASTBuilder, Decl* decl)
{
- SharedASTBuilder* sharedASTBuilder = session->m_sharedASTBuilder;
-
if (auto builtinMod = decl->findModifier<BuiltinTypeModifier>())
{
sharedASTBuilder->registerBuiltinDecl(decl, builtinMod);
@@ -3514,6 +3508,25 @@ static void _registerBuiltinDeclsRec(Session* session, Decl* decl)
{
sharedASTBuilder->registerBuiltinRequirementDecl(decl, builtinRequirement);
}
+}
+
+
+void registerBuiltinDecl(ASTBuilder* astBuilder, Decl* decl)
+{
+ registerBuiltinDecl(astBuilder->getSharedASTBuilder(), decl);
+}
+
+
+/// Recursively register any builtin declarations that need to be attached to the `session`.
+///
+/// This function should only be needed for declarations in the core module.
+///
+static void _registerBuiltinDeclsRec(Session* session, Decl* decl)
+{
+ SharedASTBuilder* sharedASTBuilder = session->m_sharedASTBuilder;
+
+ registerBuiltinDecl(sharedASTBuilder, decl);
+
if (auto containerDecl = as<ContainerDecl>(decl))
{
for (auto childDecl : containerDecl->getDirectMemberDecls())
@@ -3535,6 +3548,42 @@ void registerBuiltinDecls(Session* session, Decl* decl)
_registerBuiltinDeclsRec(session, decl);
}
+void _collectBuiltinDeclsThatNeedRegistrationRec(Decl* decl, List<Decl*>& ioDecls)
+{
+ if (decl->findModifier<BuiltinTypeModifier>())
+ {
+ ioDecls.add(decl);
+ }
+ else if (decl->findModifier<MagicTypeModifier>())
+ {
+ ioDecls.add(decl);
+ }
+ else if (decl->findModifier<BuiltinRequirementModifier>())
+ {
+ ioDecls.add(decl);
+ }
+
+ if (auto containerDecl = as<ContainerDecl>(decl))
+ {
+ for (auto childDecl : containerDecl->getDirectMemberDecls())
+ {
+ if (as<ScopeDecl>(childDecl))
+ continue;
+
+ _collectBuiltinDeclsThatNeedRegistrationRec(childDecl, ioDecls);
+ }
+ }
+ if (auto genericDecl = as<GenericDecl>(decl))
+ {
+ _collectBuiltinDeclsThatNeedRegistrationRec(genericDecl->inner, ioDecls);
+ }
+}
+
+void collectBuiltinDeclsThatNeedRegistration(ModuleDecl* moduleDecl, List<Decl*>& outDecls)
+{
+ _collectBuiltinDeclsThatNeedRegistrationRec(moduleDecl, outDecls);
+}
+
Type* unwrapArrayType(Type* type)
{
for (;;)