BsDockManagerLayoutRTTI.h 4.6 KB

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