BsDockManagerLayoutRTTI.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. #pragma once
  2. #include "BsEditorPrerequisites.h"
  3. #include "BsDockManagerLayout.h"
  4. #include "BsRTTIType.h"
  5. namespace BansheeEngine
  6. {
  7. class DockManagerLayoutRTTI : public RTTIType<DockManagerLayout, IReflectable, DockManagerLayoutRTTI>
  8. {
  9. private:
  10. DockManagerLayout::Entry& getRootEntry(DockManagerLayout* obj) { return obj->mRootEntry; }
  11. void setRootEntry(DockManagerLayout* obj, DockManagerLayout::Entry& val) { obj->mRootEntry = val; }
  12. bool& getIsMaximized(DockManagerLayout* obj) { return obj->mIsMaximized; }
  13. void setIsMaximized(DockManagerLayout* obj, bool& val) { obj->mIsMaximized = val; }
  14. Vector<String>& getMaximizedWidgetNames(DockManagerLayout* obj) { return obj->mMaximizedWidgetNames; }
  15. void setMaximizedWidgetNames(DockManagerLayout* obj, Vector<String>& val) { obj->mMaximizedWidgetNames = val; }
  16. public:
  17. DockManagerLayoutRTTI()
  18. {
  19. addPlainField("mRootEntry", 0, &DockManagerLayoutRTTI::getRootEntry, &DockManagerLayoutRTTI::setRootEntry);
  20. addPlainField("mIsMaximized", 1, &DockManagerLayoutRTTI::getIsMaximized, &DockManagerLayoutRTTI::setIsMaximized);
  21. addPlainField("mMaximizedWidgetNames", 2, &DockManagerLayoutRTTI::getMaximizedWidgetNames, &DockManagerLayoutRTTI::setMaximizedWidgetNames);
  22. }
  23. void onDeserializationEnded(IReflectable* obj) override
  24. {
  25. DockManagerLayout* layout = static_cast<DockManagerLayout*>(obj);
  26. Stack<DockManagerLayout::Entry*> todo;
  27. todo.push(&layout->mRootEntry);
  28. while (!todo.empty())
  29. {
  30. DockManagerLayout::Entry* current = todo.top();
  31. todo.pop();
  32. if (!current->isLeaf)
  33. {
  34. current->children[0]->parent = current;
  35. current->children[1]->parent = current;
  36. todo.push(current->children[0]);
  37. todo.push(current->children[1]);
  38. }
  39. }
  40. }
  41. virtual const String& getRTTIName() override
  42. {
  43. static String name = "DockManagerLayout";
  44. return name;
  45. }
  46. virtual UINT32 getRTTIId() override
  47. {
  48. return TID_DockManagerLayout;
  49. }
  50. virtual std::shared_ptr<IReflectable> newRTTIObject() override
  51. {
  52. return bs_shared_ptr_new<DockManagerLayout>();
  53. }
  54. };
  55. }
  56. namespace BansheeEngine
  57. {
  58. template<> struct RTTIPlainType<BansheeEngine::DockManagerLayout::Entry>
  59. {
  60. enum { id = BansheeEngine::TID_DockManagerLayoutEntry }; enum { hasDynamicSize = 1 };
  61. static void toMemory(const BansheeEngine::DockManagerLayout::Entry& data, char* memory)
  62. {
  63. UINT32 size = 0;
  64. char* memoryStart = memory;
  65. memory += sizeof(UINT32);
  66. size += sizeof(UINT32);
  67. memory = rttiWriteElem(data.isLeaf, memory, size);
  68. memory = rttiWriteElem(data.horizontalSplit, memory, size);
  69. memory = rttiWriteElem(data.splitPosition, memory, size);
  70. memory = rttiWriteElem(data.widgetNames, memory, size);
  71. if(!data.isLeaf)
  72. {
  73. memory = rttiWriteElem(*data.children[0], memory, size);
  74. memory = rttiWriteElem(*data.children[1], memory, size);
  75. }
  76. memcpy(memoryStart, &size, sizeof(UINT32));
  77. }
  78. static UINT32 fromMemory(BansheeEngine::DockManagerLayout::Entry& data, char* memory)
  79. {
  80. UINT32 size = 0;
  81. memcpy(&size, memory, sizeof(UINT32));
  82. memory += sizeof(UINT32);
  83. memory = rttiReadElem(data.isLeaf, memory);
  84. memory = rttiReadElem(data.horizontalSplit, memory);
  85. memory = rttiReadElem(data.splitPosition, memory);
  86. memory = rttiReadElem(data.widgetNames, memory);
  87. if(!data.isLeaf)
  88. {
  89. data.children[0] = bs_new<BansheeEngine::DockManagerLayout::Entry>();
  90. data.children[1] = bs_new<BansheeEngine::DockManagerLayout::Entry>();
  91. memory = rttiReadElem(*data.children[0], memory);
  92. memory = rttiReadElem(*data.children[1], memory);
  93. data.children[0]->parent = &data;
  94. data.children[1]->parent = &data;
  95. }
  96. return size;
  97. }
  98. static UINT32 getDynamicSize(const BansheeEngine::DockManagerLayout::Entry& data)
  99. {
  100. UINT64 dataSize = sizeof(UINT32) + rttiGetElemSize(data.isLeaf) + rttiGetElemSize(data.horizontalSplit) +
  101. rttiGetElemSize(data.splitPosition) + rttiGetElemSize(data.widgetNames);
  102. if(!data.isLeaf)
  103. {
  104. dataSize += rttiGetElemSize(*data.children[0]);
  105. dataSize += rttiGetElemSize(*data.children[1]);
  106. }
  107. #if BS_DEBUG_MODE
  108. if(dataSize > std::numeric_limits<UINT32>::max())
  109. {
  110. __string_throwDataOverflowException();
  111. }
  112. #endif
  113. return (UINT32)dataSize;
  114. }
  115. };
  116. }