CMind.cpp 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. #include "CMind.h"
  2. #include <QDebug>
  3. CNodeData::CNodeData(int projId, int indexType, int number, int pNumber, int id)
  4. : id(id), projectId(projId), indexType(indexType), number(number), pNumber(pNumber)
  5. {
  6. }
  7. bool CNodeData::isValid() const
  8. {
  9. return projectId >= 0 && indexType > 0 && number >= 0;
  10. }
  11. bool CNodeData::isNull() const
  12. {
  13. return id == -1 && projectId == -1 && indexType == 0 && number == -1 && pNumber == -1;
  14. }
  15. bool CNodeData::isCached() const
  16. {
  17. return id >= 0;
  18. }
  19. bool CNodeData::hasParent() const
  20. {
  21. return pNumber >= 0;
  22. }
  23. bool CNodeData::isSameMind(CNodeData n) const
  24. {
  25. return projectId == n.projectId && indexType == n.indexType;
  26. }
  27. CMind::CMind(QObject *parent) : QObject(parent) { }
  28. QList<CNodeData> CMind::nodeList() const
  29. {
  30. return m_nodeList;
  31. }
  32. void CMind::setNodeList(QList<CNodeData> list)
  33. {
  34. m_nodeList.clear();
  35. for (CNodeData n : list) {
  36. addNode(n);
  37. }
  38. }
  39. bool CMind::isNodeValid(CNodeData n) const
  40. {
  41. CNodeData root = node(minNumber());
  42. if (root.isValid()) {
  43. bool v = n.isValid() && n.isSameMind(root);
  44. return v;
  45. }
  46. return n.isValid();
  47. }
  48. CNodeData CMind::node(int number) const
  49. {
  50. int i = numberList().indexOf(number);
  51. if (i < 0 || i >= m_nodeList.count()) {
  52. return CNodeData();
  53. }
  54. return m_nodeList[i];
  55. }
  56. bool CMind::containsNode(int number) const
  57. {
  58. return numberList().contains(number);
  59. }
  60. bool CMind::canAddNode(CNodeData n)
  61. {
  62. // 节点无效, 不能添加
  63. if (isNodeValid(n) == false) {
  64. return false;
  65. }
  66. // 指明了父节点, 但父节点无效, 不能添加
  67. if (n.hasParent() && containsNode(n.pNumber) == false) {
  68. return false;
  69. }
  70. // 节点编号重复, 不能添加
  71. if (numberList().contains(n.number)) {
  72. return false;
  73. }
  74. return true;
  75. }
  76. void CMind::addNode(CNodeData n)
  77. {
  78. m_nodeList.append(n);
  79. }
  80. void CMind::removeNode(int number)
  81. {
  82. // 删除节点
  83. int i = numberList().indexOf(number);
  84. if (i >= 0 && i < m_nodeList.count()) {
  85. emit sigRemoveNode(m_nodeList[i].id);
  86. m_nodeList.removeAt(i);
  87. }
  88. // 删除子节点
  89. for (int i = m_nodeList.count() - 1; i >= 0; i--) {
  90. CNodeData n = m_nodeList[i];
  91. if (hasAncestor(n.number, number)) {
  92. m_nodeList.removeAt(i);
  93. emit sigRemoveNode(n.id);
  94. }
  95. }
  96. }
  97. void CMind::updateNode(CNodeData n)
  98. {
  99. for (int i = 0; i < m_nodeList.count(); i++) {
  100. if (n.id == m_nodeList[i].id) {
  101. m_nodeList.replace(i, n);
  102. break;
  103. }
  104. }
  105. }
  106. CNodeData CMind::root() const
  107. {
  108. return node(minNumber());
  109. }
  110. bool CMind::hasAncestor(int childNumber, int ancestorNumber) const
  111. {
  112. CNodeData c = node(childNumber);
  113. if (c.isValid()) {
  114. if (c.hasParent() && c.pNumber == ancestorNumber) {
  115. return true;
  116. }
  117. return hasAncestor(c.pNumber, ancestorNumber);
  118. }
  119. return false;
  120. }
  121. bool CMind::isInvalidated(int number) const
  122. {
  123. CNodeData c = node(number);
  124. if (c.isEffective) {
  125. return true;
  126. }
  127. if (c.hasParent()) {
  128. return isInvalidated(c.pNumber);
  129. }
  130. return false;
  131. }
  132. QList<int> CMind::numberList() const
  133. {
  134. QList<int> l;
  135. for (int i = 0; i < m_nodeList.count(); i++) {
  136. l.append(m_nodeList[i].number);
  137. }
  138. return l;
  139. }
  140. int CMind::maxNumber() const
  141. {
  142. int n = -1;
  143. if (m_nodeList.count() > 0) {
  144. n = m_nodeList.first().number;
  145. }
  146. for (int i = 0; i < m_nodeList.count(); i++) {
  147. n = std::max(n, m_nodeList[i].number);
  148. }
  149. return n;
  150. }
  151. int CMind::minNumber() const
  152. {
  153. int n = -1;
  154. if (m_nodeList.count() > 0) {
  155. n = m_nodeList.first().number;
  156. }
  157. for (int i = 0; i < m_nodeList.count(); i++) {
  158. n = std::min(n, m_nodeList[i].number);
  159. }
  160. return n;
  161. }
  162. void CMind::clear()
  163. {
  164. m_nodeList.clear();
  165. }
  166. int CMind::levelOfNode(CNodeData n) const
  167. {
  168. int l = 1;
  169. if (n.hasParent()) {
  170. CNodeData p = node(n.pNumber);
  171. l = levelOfNode(p) + 1;
  172. }
  173. return l;
  174. }
  175. int CMind::levels() const
  176. {
  177. int l = 0;
  178. for (CNodeData n : m_nodeList) {
  179. l = std::max(l, levelOfNode(n));
  180. }
  181. return l;
  182. }
  183. QList<CNodeData> CMind::nodesInLevel(int i) const
  184. {
  185. QList<CNodeData> l;
  186. for (CNodeData n : m_nodeList) {
  187. if (levelOfNode(n) == i) {
  188. l.append(n);
  189. }
  190. }
  191. return l;
  192. }
  193. QList<CNodeData> CMind::subNodes(CNodeData n) const
  194. {
  195. QList<CNodeData> l;
  196. for (CNodeData t : m_nodeList) {
  197. if (t.pNumber == n.number) {
  198. l.append(t);
  199. }
  200. }
  201. return l;
  202. }
  203. int CMind::leavesCountOfNode(CNodeData n) const
  204. {
  205. int d = 0;
  206. QList<CNodeData> list = subNodes(n);
  207. if (list.count() > 0) {
  208. for (CNodeData sub : list) {
  209. d += leavesCountOfNode(sub);
  210. }
  211. } else {
  212. d++;
  213. }
  214. return d;
  215. }
  216. int CMind::leavesCount() const
  217. {
  218. return leavesCountOfNode(root());
  219. }
  220. QList<CNodeData> CMind::leavesOfNode(CNodeData n) const
  221. {
  222. QList<CNodeData> list;
  223. QList<CNodeData> subList = subNodes(n);
  224. if (subList.count() > 0) {
  225. for (CNodeData sub : subList) {
  226. list.append(leavesOfNode(sub));
  227. }
  228. } else {
  229. list.append(n);
  230. }
  231. return list;
  232. }
  233. QList<CNodeData> CMind::leaves() const
  234. {
  235. return leavesOfNode(root());
  236. }
  237. void CMind::getSeqNodes(QList<QList<SeqNode>> &seqNodes) const
  238. {
  239. for (int i = 1; i < this->levels(); ++i) {
  240. seqNodes << QList<SeqNode>();
  241. }
  242. QMap<QString, QStringList> all;
  243. for (int i = 1; i < this->levels(); i++) {
  244. QList<CNodeData> nodes = this->nodesInLevel(i);
  245. for (const CNodeData &node : nodes) {
  246. QList<CNodeData> subNodes = this->subNodes(node);
  247. SeqNode snode;
  248. snode.name = node.name.trimmed();
  249. for (const CNodeData &sub : subNodes) {
  250. snode.childs.append(sub.name.trimmed());
  251. }
  252. seqNodes[i - 1].append(snode);
  253. }
  254. }
  255. }
  256. const CNode *CMind::nodeObject() const
  257. {
  258. CNode *node = nullptr;
  259. return node;
  260. }