Counter Strike : Global Offensive Source Code
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

185 lines
5.1 KiB

  1. //====== Copyright � 1996-2004, Valve Corporation, All rights reserved. =======
  2. //
  3. // Purpose:
  4. //
  5. //=============================================================================
  6. #ifndef DMELEMENTDICTIONARY_H
  7. #define DMELEMENTDICTIONARY_H
  8. #ifdef _WIN32
  9. #pragma once
  10. #endif
  11. #include "tier1/utlvector.h"
  12. #include "datamodel/idatamodel.h"
  13. #include "datamodel/dmattribute.h"
  14. #include "tier1/utlrbtree.h"
  15. #include "tier1/utlhash.h"
  16. //-----------------------------------------------------------------------------
  17. // Forward declarations
  18. //-----------------------------------------------------------------------------
  19. class CDmElement;
  20. class CDmAttribute;
  21. //-----------------------------------------------------------------------------
  22. // Element dictionary used in unserialization
  23. //-----------------------------------------------------------------------------
  24. typedef int DmElementDictHandle_t;
  25. enum
  26. {
  27. ELEMENT_DICT_HANDLE_INVALID = (DmElementDictHandle_t)~0
  28. };
  29. class CDmElementDictionary
  30. {
  31. public:
  32. CDmElementDictionary();
  33. DmElementDictHandle_t InsertElement( CDmElement *pElement );
  34. CDmElement *GetElement( DmElementDictHandle_t handle );
  35. void AddAttribute( CDmAttribute *pAttribute, const DmObjectId_t &pElementId );
  36. void AddArrayAttribute( CDmAttribute *pAttribute, DmElementDictHandle_t hChild );
  37. void AddArrayAttribute( CDmAttribute *pAttribute, const DmObjectId_t &pElementId );
  38. DmElementHandle_t SetElementId( DmElementDictHandle_t hDictHandle,
  39. const DmObjectId_t &newId,
  40. DmConflictResolution_t idConflictResolution );
  41. // Finds an element into the table
  42. DmElementDictHandle_t FindElement( CDmElement *pElement );
  43. // Hook up all element references (which were unserialized as object ids)
  44. void HookUpElementReferences();
  45. // Clears the dictionary
  46. void Clear();
  47. // iteration through elements
  48. DmElementDictHandle_t FirstElement() { return 0; }
  49. DmElementDictHandle_t NextElement( DmElementDictHandle_t h )
  50. {
  51. return m_Dict.IsValidIndex( h+1 ) ? h+1 : ELEMENT_DICT_HANDLE_INVALID;
  52. }
  53. private:
  54. struct AttributeInfo_t
  55. {
  56. CDmAttribute *m_pAttribute;
  57. int m_bId;
  58. union
  59. {
  60. DmElementDictHandle_t m_hElement;
  61. DmObjectId_t m_ObjectId;
  62. };
  63. };
  64. typedef CUtlVector<AttributeInfo_t> AttributeList_t;
  65. struct DmIdPair_t
  66. {
  67. DmObjectId_t m_oldId;
  68. DmObjectId_t m_newId;
  69. DmIdPair_t() {}
  70. DmIdPair_t( const DmObjectId_t &id )
  71. {
  72. CopyUniqueId( id, &m_oldId );
  73. }
  74. DmIdPair_t( const DmObjectId_t &oldId, const DmObjectId_t &newId )
  75. {
  76. CopyUniqueId( oldId, &m_oldId );
  77. CopyUniqueId( newId, &m_newId );
  78. }
  79. DmIdPair_t &operator=( const DmIdPair_t &that )
  80. {
  81. CopyUniqueId( that.m_oldId, &m_oldId );
  82. CopyUniqueId( that.m_newId, &m_newId );
  83. return *this;
  84. }
  85. static unsigned int HashKey( const DmIdPair_t& that )
  86. {
  87. return *( unsigned int* )&that.m_oldId.m_Value;
  88. }
  89. static bool Compare( const DmIdPair_t& a, const DmIdPair_t& b )
  90. {
  91. // caveat emptor: this comparison facilitates searching by just 'from' ID, but also means that ( A -> B ) will match ( A -> C )
  92. return IsUniqueIdEqual( a.m_oldId, b.m_oldId );
  93. }
  94. };
  95. struct DeletionInfo_t
  96. {
  97. DeletionInfo_t() {}
  98. DeletionInfo_t( DmElementHandle_t hElement ) : m_hElementToDelete( hElement ) {}
  99. bool operator==( const DeletionInfo_t& src ) const { return m_hElementToDelete == src.m_hElementToDelete; }
  100. DmElementDictHandle_t m_hDictHandle;
  101. DmElementHandle_t m_hElementToDelete;
  102. DmElementHandle_t m_hReplacementElement;
  103. };
  104. // Hook up all element references (which were unserialized as object ids)
  105. void HookUpElementAttributes();
  106. void HookUpElementArrayAttributes();
  107. void RemoveAttributeInfosOfElement( AttributeList_t &attributes, DmElementHandle_t hElement );
  108. CUtlVector< DmElementHandle_t > m_Dict;
  109. AttributeList_t m_Attributes;
  110. AttributeList_t m_ArrayAttributes;
  111. CUtlVector< DeletionInfo_t > m_elementsToDelete;
  112. CUtlHash< DmIdPair_t > m_idmap;
  113. };
  114. //-----------------------------------------------------------------------------
  115. // Element dictionary used in serialization
  116. //-----------------------------------------------------------------------------
  117. class CDmElementSerializationDictionary
  118. {
  119. public:
  120. CDmElementSerializationDictionary();
  121. // Creates the list of all things to serialize
  122. void BuildElementList( CDmElement *pRoot, bool bFlatMode );
  123. // Should I inline the serialization of this element?
  124. bool ShouldInlineElement( CDmElement *pElement );
  125. // Clears the dictionary
  126. void Clear();
  127. // Iterates over all root elements to serialize
  128. DmElementDictHandle_t FirstRootElement() const;
  129. DmElementDictHandle_t NextRootElement( DmElementDictHandle_t h ) const;
  130. CDmElement* GetRootElement( DmElementDictHandle_t h );
  131. // Finds the handle of the element
  132. DmElementDictHandle_t Find( CDmElement *pElement );
  133. // How many root elements do we have?
  134. int RootElementCount() const;
  135. private:
  136. struct ElementInfo_t
  137. {
  138. bool m_bRoot;
  139. CDmElement* m_pElement;
  140. };
  141. // Creates the list of all things to serialize
  142. void BuildElementList_R( CDmElement *pRoot, bool bFlatMode, bool bIsRoot );
  143. static bool LessFunc( const ElementInfo_t &lhs, const ElementInfo_t &rhs );
  144. CUtlBlockRBTree< ElementInfo_t, DmElementDictHandle_t > m_Dict;
  145. };
  146. #endif // DMELEMENTDICTIONARY_H