Factory.cpp 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. // Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
  2. // SPDX-FileCopyrightText: 2021 Jorrit Rouwe
  3. // SPDX-License-Identifier: MIT
  4. #include <Jolt/Jolt.h>
  5. #include <Jolt/Core/Factory.h>
  6. JPH_NAMESPACE_BEGIN
  7. Factory *Factory::sInstance = nullptr;
  8. void *Factory::CreateObject(const char *inName)
  9. {
  10. const RTTI *ci = Find(inName);
  11. return ci != nullptr? ci->CreateObject() : nullptr;
  12. }
  13. const RTTI *Factory::Find(const char *inName)
  14. {
  15. ClassNameMap::iterator c = mClassNameMap.find(inName);
  16. return c != mClassNameMap.end()? c->second : nullptr;
  17. }
  18. const RTTI *Factory::Find(uint32 inHash)
  19. {
  20. ClassHashMap::iterator c = mClassHashMap.find(inHash);
  21. return c != mClassHashMap.end()? c->second : nullptr;
  22. }
  23. bool Factory::Register(const RTTI *inRTTI)
  24. {
  25. // Check if we already know the type
  26. if (Find(inRTTI->GetName()) != nullptr)
  27. return true;
  28. // Insert this class by name
  29. mClassNameMap.try_emplace(inRTTI->GetName(), inRTTI);
  30. // Insert this class by hash
  31. if (!mClassHashMap.try_emplace(inRTTI->GetHash(), inRTTI).second)
  32. {
  33. JPH_ASSERT(false, "Hash collision registering type!");
  34. return false;
  35. }
  36. // Register base classes
  37. for (int i = 0; i < inRTTI->GetBaseClassCount(); ++i)
  38. if (!Register(inRTTI->GetBaseClass(i)))
  39. return false;
  40. #ifdef JPH_OBJECT_STREAM
  41. // Register attribute classes
  42. for (int i = 0; i < inRTTI->GetAttributeCount(); ++i)
  43. {
  44. const RTTI *rtti = inRTTI->GetAttribute(i).GetMemberPrimitiveType();
  45. if (rtti != nullptr && !Register(rtti))
  46. return false;
  47. }
  48. #endif // JPH_OBJECT_STREAM
  49. return true;
  50. }
  51. bool Factory::Register(const RTTI **inRTTIs, uint inNumber)
  52. {
  53. for (const RTTI **rtti = inRTTIs; rtti < inRTTIs + inNumber; ++rtti)
  54. if (!Register(*rtti))
  55. return false;
  56. return true;
  57. }
  58. void Factory::Clear()
  59. {
  60. mClassNameMap.clear();
  61. mClassHashMap.clear();
  62. }
  63. Array<const RTTI *> Factory::GetAllClasses() const
  64. {
  65. Array<const RTTI *> all_classes;
  66. all_classes.reserve(mClassNameMap.size());
  67. for (const ClassNameMap::value_type &c : mClassNameMap)
  68. all_classes.push_back(c.second);
  69. return all_classes;
  70. }
  71. JPH_NAMESPACE_END