XRefNodeManager.hpp 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  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 _WIN32
  21. #ifdef DFUXREFLIB_EXPORTS
  22. #define DFUXREFNODEMANAGERLIB_API __declspec(dllexport)
  23. #else
  24. #define DFUXREFNODEMANAGERLIB_API __declspec(dllimport)
  25. #endif
  26. #else
  27. #define DFUXREFNODEMANAGERLIB_API
  28. #endif
  29. #include "XRefFilesNode.hpp"
  30. interface IXRefProgressCallback: extends IInterface
  31. {
  32. virtual void progress(const char *text)=0;
  33. virtual void error(const char *text)=0;
  34. };
  35. interface IConstXRefNode : extends IInterface
  36. {
  37. virtual StringBuffer & getName(StringBuffer & str) = 0;
  38. virtual StringBuffer & getLastModified(StringBuffer & str) = 0;
  39. virtual StringBuffer& getXRefData(StringBuffer & buff) = 0;
  40. virtual StringBuffer& getStatus(StringBuffer & buff) = 0;
  41. virtual IXRefFilesNode* getLostFiles() = 0;
  42. virtual IXRefFilesNode* getFoundFiles() = 0;
  43. virtual IXRefFilesNode* getOrphanFiles() = 0;
  44. virtual StringBuffer& getCluster(StringBuffer& Cluster) = 0;
  45. virtual bool useSasha() = 0;
  46. };
  47. interface IXRefNode : extends IConstXRefNode
  48. {
  49. virtual void setName(const char* str) = 0;
  50. virtual void BuildXRefData(IPropertyTree & pTree,const char* Cluster) = 0;
  51. virtual void setStatus(const char* str) = 0;
  52. virtual void commit() = 0;
  53. virtual void setCluster(const char* str) = 0;
  54. virtual StringBuffer &serializeMessages(StringBuffer &buf) = 0;
  55. virtual void deserializeMessages(IPropertyTree& inTree) = 0;
  56. virtual StringBuffer &serializeDirectories(StringBuffer &buf) = 0;
  57. virtual void deserializeDirectories(IPropertyTree& inTree) = 0;
  58. virtual bool removeEmptyDirectories(StringBuffer &errstr) = 0;
  59. };
  60. interface IXRefNodeManager : extends IInterface
  61. {
  62. virtual IXRefNode * getXRefNode(const char* NodeName) = 0;
  63. virtual IXRefNode * CreateXRefNode(const char* NodeName) = 0;
  64. };
  65. extern DFUXREFNODEMANAGERLIB_API IXRefNodeManager * CreateXRefNodeFactory();
  66. class CXRefNode : implements IXRefNode ,implements IXRefProgressCallback, public CInterface
  67. {
  68. private:
  69. Owned<IRemoteConnection> m_conn;
  70. StringBuffer m_origName;
  71. Owned<IPropertyTree> m_XRefTree;
  72. Owned<IPropertyTree> m_XRefDataTree;
  73. Owned<IXRefFilesNode> m_orphans;
  74. Owned<IXRefFilesNode> m_lost;
  75. Owned<IXRefFilesNode> m_found;
  76. Owned<IPropertyTree> m_messages;
  77. Owned<IPropertyTree> m_directories;
  78. bool m_bChanged;
  79. StringBuffer m_dataStr;
  80. StringBuffer m_ClusterName;
  81. Mutex commitMutex;
  82. private:
  83. IPropertyTree& getDataTree();
  84. public:
  85. IMPLEMENT_IINTERFACE;
  86. CXRefNode();
  87. CXRefNode(IPropertyTree* pTreeRoot);
  88. CXRefNode(const char* clusterName,IRemoteConnection *conn);
  89. virtual ~CXRefNode();
  90. bool IsChanged();
  91. void SetChanged(bool bChanged);
  92. //IXRefProgressCallback
  93. void progress(const char *text);
  94. void error(const char *text);
  95. //IConstXRefNode
  96. StringBuffer & getName(StringBuffer & str);
  97. StringBuffer & getLastModified(StringBuffer & str);
  98. bool useSasha();
  99. StringBuffer& getXRefData(StringBuffer & buff);
  100. StringBuffer& getStatus(StringBuffer & buff);
  101. void setLastModified(IJlibDateTime& DateTime);
  102. IXRefFilesNode* getLostFiles();
  103. IXRefFilesNode* getFoundFiles();
  104. IXRefFilesNode* getOrphanFiles();
  105. StringBuffer &serializeMessages(StringBuffer &buf);
  106. void deserializeMessages(IPropertyTree& inTree);
  107. StringBuffer &serializeDirectories(StringBuffer &buf);
  108. void deserializeDirectories(IPropertyTree& inTree);
  109. bool removeEmptyDirectories(StringBuffer &errstr);
  110. //IXRefNode
  111. void setName(const char* str);
  112. void setXRefData(StringBuffer & buff);
  113. void setXRefData(IPropertyTree & pTree);
  114. void BuildXRefData(IPropertyTree & pTree,const char* Cluster);
  115. void setStatus(const char* str);
  116. void commit();
  117. virtual StringBuffer& getCluster(StringBuffer& Cluster);
  118. virtual void setCluster(const char* str);
  119. };
  120. class CXRefNodeManager : implements IXRefNodeManager, public CInterface
  121. {
  122. public:
  123. IMPLEMENT_IINTERFACE;
  124. CXRefNodeManager(){};
  125. virtual ~CXRefNodeManager(){};
  126. IXRefNode * getXRefNode(const char* NodeName);
  127. IXRefNode * CreateXRefNode(const char* NodeName);
  128. };
  129. #endif //