XRefNodeManager.hpp 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. /*##############################################################################
  2. HPCC SYSTEMS software Copyright (C) 2012 HPCC Systems®.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. ############################################################################## */
  13. // XRefNodeManager.h: interface for the CXRefNodeManager class.
  14. //
  15. //////////////////////////////////////////////////////////////////////
  16. #ifndef XREFNODEMANAGER_HPP
  17. #define XREFNODEMANAGER_HPP
  18. #include "jstring.hpp"
  19. #include "dasds.hpp"
  20. #ifdef DFUXREFLIB_EXPORTS
  21. #define DFUXREFNODEMANAGERLIB_API DECL_EXPORT
  22. #else
  23. #define DFUXREFNODEMANAGERLIB_API DECL_IMPORT
  24. #endif
  25. #include "XRefFilesNode.hpp"
  26. interface IXRefProgressCallback: extends IInterface
  27. {
  28. virtual void progress(const char *text)=0;
  29. virtual void error(const char *text)=0;
  30. };
  31. interface IConstXRefNode : extends IInterface
  32. {
  33. virtual StringBuffer & getName(StringBuffer & str) = 0;
  34. virtual StringBuffer & getLastModified(StringBuffer & str) = 0;
  35. virtual StringBuffer& getXRefData(StringBuffer & buff) = 0;
  36. virtual StringBuffer& getStatus(StringBuffer & buff) = 0;
  37. virtual IXRefFilesNode* getLostFiles() = 0;
  38. virtual IXRefFilesNode* getFoundFiles() = 0;
  39. virtual IXRefFilesNode* getOrphanFiles() = 0;
  40. virtual StringBuffer& getCluster(StringBuffer& Cluster) = 0;
  41. virtual bool useSasha() = 0;
  42. };
  43. interface IXRefNode : extends IConstXRefNode
  44. {
  45. virtual void setName(const char* str) = 0;
  46. virtual void BuildXRefData(IPropertyTree & pTree,const char* Cluster) = 0;
  47. virtual void setStatus(const char* str) = 0;
  48. virtual void commit() = 0;
  49. virtual void setCluster(const char* str) = 0;
  50. virtual StringBuffer &serializeMessages(StringBuffer &buf) = 0;
  51. virtual void deserializeMessages(IPropertyTree& inTree) = 0;
  52. virtual StringBuffer &serializeDirectories(StringBuffer &buf) = 0;
  53. virtual void deserializeDirectories(IPropertyTree& inTree) = 0;
  54. virtual bool removeEmptyDirectories(StringBuffer &errstr) = 0;
  55. };
  56. interface IXRefNodeManager : extends IInterface
  57. {
  58. virtual IXRefNode * getXRefNode(const char* NodeName) = 0;
  59. virtual IXRefNode * CreateXRefNode(const char* NodeName) = 0;
  60. };
  61. extern DFUXREFNODEMANAGERLIB_API IXRefNodeManager * CreateXRefNodeFactory();
  62. class CXRefNode : implements IXRefNode ,implements IXRefProgressCallback, public CInterface
  63. {
  64. private:
  65. Owned<IRemoteConnection> m_conn;
  66. StringBuffer m_origName;
  67. Owned<IPropertyTree> m_XRefTree;
  68. Owned<IPropertyTree> m_XRefDataTree;
  69. Owned<IXRefFilesNode> m_orphans;
  70. Owned<IXRefFilesNode> m_lost;
  71. Owned<IXRefFilesNode> m_found;
  72. Owned<IPropertyTree> m_messages;
  73. Owned<IPropertyTree> m_directories;
  74. bool m_bChanged;
  75. StringBuffer m_dataStr;
  76. StringBuffer m_ClusterName;
  77. Mutex commitMutex;
  78. private:
  79. IPropertyTree& getDataTree();
  80. public:
  81. IMPLEMENT_IINTERFACE;
  82. CXRefNode();
  83. CXRefNode(IPropertyTree* pTreeRoot);
  84. CXRefNode(const char* clusterName,IRemoteConnection *conn);
  85. virtual ~CXRefNode();
  86. bool IsChanged();
  87. void SetChanged(bool bChanged);
  88. //IXRefProgressCallback
  89. void progress(const char *text);
  90. void error(const char *text);
  91. //IConstXRefNode
  92. StringBuffer & getName(StringBuffer & str);
  93. StringBuffer & getLastModified(StringBuffer & str);
  94. bool useSasha();
  95. StringBuffer& getXRefData(StringBuffer & buff);
  96. StringBuffer& getStatus(StringBuffer & buff);
  97. void setLastModified(IJlibDateTime& DateTime);
  98. IXRefFilesNode* getLostFiles();
  99. IXRefFilesNode* getFoundFiles();
  100. IXRefFilesNode* getOrphanFiles();
  101. StringBuffer &serializeMessages(StringBuffer &buf);
  102. void deserializeMessages(IPropertyTree& inTree);
  103. StringBuffer &serializeDirectories(StringBuffer &buf);
  104. void deserializeDirectories(IPropertyTree& inTree);
  105. bool removeEmptyDirectories(StringBuffer &errstr);
  106. //IXRefNode
  107. void setName(const char* str);
  108. void setXRefData(StringBuffer & buff);
  109. void setXRefData(IPropertyTree & pTree);
  110. void BuildXRefData(IPropertyTree & pTree,const char* Cluster);
  111. void setStatus(const char* str);
  112. void commit();
  113. virtual StringBuffer& getCluster(StringBuffer& Cluster);
  114. virtual void setCluster(const char* str);
  115. };
  116. class CXRefNodeManager : implements IXRefNodeManager, public CInterface
  117. {
  118. public:
  119. IMPLEMENT_IINTERFACE;
  120. CXRefNodeManager(){};
  121. virtual ~CXRefNodeManager(){};
  122. IXRefNode * getXRefNode(const char* NodeName);
  123. IXRefNode * CreateXRefNode(const char* NodeName);
  124. };
  125. #endif //