BsDockManagerLayoutRTTI.h 4.4 KB

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