XRefNodeManager.hpp 5.4 KB

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