CMind.cpp 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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. CMind::CMind(int projId, int evalType, QObject *parent) : QObject(parent), m_projectId(projId), m_evalType(evalType) { }
  23. QList<CNodeData> CMind::nodeList() const
  24. {
  25. return m_nodeList;
  26. }
  27. void CMind::setNodeList(QList<CNodeData> list)
  28. {
  29. m_nodeList.clear();
  30. for (CNodeData n : list) {
  31. addNode(n);
  32. }
  33. }
  34. bool CMind::isNodeValid(CNodeData n) const
  35. {
  36. bool v = n.isValid() && n.projectId == m_projectId && n.evalType == m_evalType;
  37. return v;
  38. }
  39. CNodeData CMind::node(int number) const
  40. {
  41. int i = numberList().indexOf(number);
  42. if (i < 0 || i >= m_nodeList.count()) {
  43. return CNodeData();
  44. }
  45. return m_nodeList[i];
  46. }
  47. bool CMind::containsNode(CNodeData n) const
  48. {
  49. return isNodeValid(n) && node(n.number).isValid();
  50. }
  51. CNodeData CMind::createNode(CNodeData parent)
  52. {
  53. CNodeData n;
  54. if (containsNode(parent) || (parent.isNull() && m_nodeList.count() <= 0)) {
  55. n = CNodeData(m_projectId, m_evalType, maxNumber() + 1, parent.number);
  56. }
  57. return n;
  58. }
  59. void CMind::addNode(CNodeData n)
  60. {
  61. if (isNodeValid(n) == false) {
  62. return;
  63. }
  64. if (numberList().contains(n.number)) {
  65. return;
  66. }
  67. m_nodeList.append(n);
  68. }
  69. void CMind::removeNode(int number, bool removeChildren)
  70. {
  71. for (int i = m_nodeList.count() - 1; i >= 0; i--) {
  72. CNodeData n = m_nodeList[i];
  73. if (n.number == number || (removeChildren && n.pNumber == number)) {
  74. m_nodeList.removeAt(i);
  75. }
  76. }
  77. }
  78. QList<int> CMind::numberList() const
  79. {
  80. QList<int> l;
  81. for (int i = 0; i < m_nodeList.count(); i++) {
  82. l.append(m_nodeList[i].number);
  83. }
  84. return l;
  85. }
  86. int CMind::maxNumber() const
  87. {
  88. int n = -1;
  89. if (m_nodeList.count() > 0) {
  90. n = m_nodeList.first().number;
  91. }
  92. for (int i = 0; i < m_nodeList.count(); i++) {
  93. n = std::max(n, m_nodeList[i].number);
  94. }
  95. return n;
  96. }
  97. int CMind::minNumber() const
  98. {
  99. int n = -1;
  100. if (m_nodeList.count() > 0) {
  101. n = m_nodeList.first().number;
  102. }
  103. for (int i = 0; i < m_nodeList.count(); i++) {
  104. n = std::min(n, m_nodeList[i].number);
  105. }
  106. return n;
  107. }