CMind.cpp 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. #include "CMind.h"
  2. CNodeData::CNodeData(int projId, int evalType, int number, int pNumber, int id)
  3. : id(id), projectId(projId), evalType(evalType), number(number), pNumber(pNumber)
  4. {
  5. }
  6. bool CNodeData::isValid() const
  7. {
  8. return projectId >= 0 && evalType > 0 && number >= 0;
  9. }
  10. bool CNodeData::isNull() const
  11. {
  12. return id == -1 && projectId == -1 && evalType == 0 && number == -1 && pNumber == -1;
  13. }
  14. bool CNodeData::isCached() const
  15. {
  16. return id >= 0;
  17. }
  18. bool CNodeData::hasParent() const
  19. {
  20. return pNumber >= 0;
  21. }
  22. bool CNodeData::isSameMind(CNodeData n) const
  23. {
  24. return projectId == n.projectId && evalType == n.evalType;
  25. }
  26. CMind::CMind(QObject *parent) : QObject(parent) { }
  27. QList<CNodeData> CMind::nodeList() const
  28. {
  29. return m_nodeList;
  30. }
  31. void CMind::setNodeList(QList<CNodeData> list)
  32. {
  33. m_nodeList.clear();
  34. for (CNodeData n : list) {
  35. addNode(n);
  36. }
  37. }
  38. bool CMind::isNodeValid(CNodeData n) const
  39. {
  40. CNodeData root = node(minNumber());
  41. if (root.isValid()) {
  42. bool v = n.isValid() && n.isSameMind(root);
  43. return v;
  44. }
  45. return n.isValid();
  46. }
  47. CNodeData CMind::node(int number) const
  48. {
  49. int i = numberList().indexOf(number);
  50. if (i < 0 || i >= m_nodeList.count()) {
  51. return CNodeData();
  52. }
  53. return m_nodeList[i];
  54. }
  55. bool CMind::containsNode(int number) const
  56. {
  57. return numberList().contains(number);
  58. }
  59. void CMind::addNode(CNodeData n)
  60. {
  61. // 节点无效, 不添加
  62. if (isNodeValid(n) == false) {
  63. return;
  64. }
  65. // 指明了父节点, 但父节点无效, 不添加
  66. if (n.hasParent() && containsNode(n.pNumber) == false) {
  67. return;
  68. }
  69. // 节点编号重复, 不添加
  70. if (numberList().contains(n.number)) {
  71. return;
  72. }
  73. m_nodeList.append(n);
  74. }
  75. void CMind::removeNode(int number)
  76. {
  77. // 若是根节点, 则整体删除
  78. if (number == minNumber()) {
  79. m_nodeList.clear();
  80. return;
  81. }
  82. // 删除节点
  83. int i = numberList().indexOf(number);
  84. if (i >= 0 && i < m_nodeList.count()) {
  85. m_nodeList.removeAt(i);
  86. }
  87. // 删除子节点
  88. for (int i = m_nodeList.count() - 1; i >= 0; i--) {
  89. CNodeData n = m_nodeList[i];
  90. if (hasAncestor(n.number, number)) {
  91. m_nodeList.removeAt(i);
  92. }
  93. }
  94. }
  95. CNodeData CMind::root() const
  96. {
  97. return node(minNumber());
  98. ;
  99. }
  100. bool CMind::hasAncestor(int childNumber, int ancestorNumber) const
  101. {
  102. CNodeData c = node(childNumber);
  103. if (c.isValid()) {
  104. if (c.hasParent() && c.pNumber == ancestorNumber) {
  105. return true;
  106. }
  107. return hasAncestor(c.pNumber, ancestorNumber);
  108. }
  109. return false;
  110. }
  111. QList<int> CMind::numberList() const
  112. {
  113. QList<int> l;
  114. for (int i = 0; i < m_nodeList.count(); i++) {
  115. l.append(m_nodeList[i].number);
  116. }
  117. return l;
  118. }
  119. int CMind::maxNumber() const
  120. {
  121. int n = -1;
  122. if (m_nodeList.count() > 0) {
  123. n = m_nodeList.first().number;
  124. }
  125. for (int i = 0; i < m_nodeList.count(); i++) {
  126. n = std::max(n, m_nodeList[i].number);
  127. }
  128. return n;
  129. }
  130. int CMind::minNumber() const
  131. {
  132. int n = -1;
  133. if (m_nodeList.count() > 0) {
  134. n = m_nodeList.first().number;
  135. }
  136. for (int i = 0; i < m_nodeList.count(); i++) {
  137. n = std::min(n, m_nodeList[i].number);
  138. }
  139. return n;
  140. }