diff --git a/tools/mkclass/classcompiler.cpp b/tools/mkclass/classcompiler.cpp index 3a49576b87d..f85719ac5df 100644 --- a/tools/mkclass/classcompiler.cpp +++ b/tools/mkclass/classcompiler.cpp @@ -376,19 +376,32 @@ void ClassCompiler::HandleClass(const Klass& klass, const ClassDebugInfo&) << "}" << std::endl << std::endl; /* GetLoadDependencies */ - m_Header << "\t" << "const std::unordered_set& GetLoadDependencies() const override;" << std::endl; + if (!klass.LoadDependencies.empty()) { + m_Header << "\tconst std::unordered_set& GetLoadDependencies() const override;" << std::endl; - m_Impl << "const std::unordered_set& TypeImpl<" << klass.Name << ">::GetLoadDependencies() const" << std::endl - << "{" << std::endl - << "\t" << "static const std::unordered_set deps ({" << std::endl; + m_Impl << "const std::unordered_set& TypeImpl<" << klass.Name << ">::GetLoadDependencies() const" << std::endl + << "{" << std::endl + << "\tstatic const auto deps ([] {" << std::endl; - for (const std::string& dep : klass.LoadDependencies) - m_Impl << "\t\t" << "GetByName(\"" << dep << "\").get()," << std::endl; + for (auto& dep : klass.LoadDependencies) + m_Impl << "\t\tauto type" << dep << " (GetByName(\"" << dep << "\").get());" << std::endl; - m_Impl << "\t" << "});" << std::endl; + m_Impl << std::endl; - m_Impl << "\t" << "return deps;" << std::endl - << "}" << std::endl << std::endl; + for (auto& dep : klass.LoadDependencies) + m_Impl << "\t\tVERIFY(type" << dep << ");" << std::endl; + + m_Impl << std::endl + << "\t\treturn std::unordered_set{"; + + for (const std::string& dep : klass.LoadDependencies) + m_Impl << " type" << dep << ","; + + m_Impl << " };" << std::endl + << "\t}());" << std::endl << std::endl + << "\treturn deps;" << std::endl + << "}" << std::endl << std::endl; + } /* GetActivationPriority */ m_Header << "\t" << "int GetActivationPriority() const override;" << std::endl; @@ -1463,6 +1476,7 @@ void ClassCompiler::CompileStream(const std::string& path, std::istream& input, << "#include \"base/objectlock.hpp\"" << std::endl << "#include \"base/utility.hpp\"" << std::endl << "#include \"base/convert.hpp\"" << std::endl + << "#include \"base/debug.hpp\"" << std::endl << "#include \"base/dependencygraph.hpp\"" << std::endl << "#include \"base/logger.hpp\"" << std::endl << "#include \"base/function.hpp\"" << std::endl