123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- #include "CMind.h"
- CNodeData::CNodeData(int projId, int evalType, int number, int pNumber, int id)
- : id(id), projectId(projId), evalType(evalType), number(number), pNumber(pNumber)
- {
- }
- bool CNodeData::isValid() const
- {
- return projectId >= 0 && evalType > 0 && number >= 0;
- }
- bool CNodeData::isNull() const
- {
- return id == -1 && projectId == -1 && evalType == 0 && number == -1 && pNumber == -1;
- }
- bool CNodeData::isCached() const
- {
- return id >= 0;
- }
- bool CNodeData::hasParent() const
- {
- return pNumber >= 0;
- }
- bool CNodeData::isSameMind(CNodeData n) const
- {
- return projectId == n.projectId && evalType == n.evalType;
- }
- CMind::CMind(QObject *parent) : QObject(parent) { }
- QList<CNodeData> CMind::nodeList() const
- {
- return m_nodeList;
- }
- void CMind::setNodeList(QList<CNodeData> list)
- {
- m_nodeList.clear();
- for (CNodeData n : list) {
- addNode(n);
- }
- }
- bool CMind::isNodeValid(CNodeData n) const
- {
- CNodeData root = node(minNumber());
- if (root.isValid()) {
- bool v = n.isValid() && n.isSameMind(root);
- return v;
- }
- return n.isValid();
- }
- CNodeData CMind::node(int number) const
- {
- int i = numberList().indexOf(number);
- if (i < 0 || i >= m_nodeList.count()) {
- return CNodeData();
- }
- return m_nodeList[i];
- }
- bool CMind::containsNode(int number) const
- {
- return numberList().contains(number);
- }
- void CMind::addNode(CNodeData n)
- {
- // 节点无效, 不添加
- if (isNodeValid(n) == false) {
- return;
- }
- // 指明了父节点, 但父节点无效, 不添加
- if (n.hasParent() && containsNode(n.pNumber) == false) {
- return;
- }
- // 节点编号重复, 不添加
- if (numberList().contains(n.number)) {
- return;
- }
- m_nodeList.append(n);
- }
- void CMind::removeNode(int number)
- {
- // 若是根节点, 则整体删除
- if (number == minNumber()) {
- m_nodeList.clear();
- return;
- }
- // 删除节点
- int i = numberList().indexOf(number);
- if (i >= 0 && i < m_nodeList.count()) {
- m_nodeList.removeAt(i);
- }
- // 删除子节点
- for (int i = m_nodeList.count() - 1; i >= 0; i--) {
- CNodeData n = m_nodeList[i];
- if (hasAncestor(n.number, number)) {
- m_nodeList.removeAt(i);
- }
- }
- }
- CNodeData CMind::root() const
- {
- return node(minNumber());
- ;
- }
- bool CMind::hasAncestor(int childNumber, int ancestorNumber) const
- {
- CNodeData c = node(childNumber);
- if (c.isValid()) {
- if (c.hasParent() && c.pNumber == ancestorNumber) {
- return true;
- }
- return hasAncestor(c.pNumber, ancestorNumber);
- }
- return false;
- }
- QList<int> CMind::numberList() const
- {
- QList<int> l;
- for (int i = 0; i < m_nodeList.count(); i++) {
- l.append(m_nodeList[i].number);
- }
- return l;
- }
- int CMind::maxNumber() const
- {
- int n = -1;
- if (m_nodeList.count() > 0) {
- n = m_nodeList.first().number;
- }
- for (int i = 0; i < m_nodeList.count(); i++) {
- n = std::max(n, m_nodeList[i].number);
- }
- return n;
- }
- int CMind::minNumber() const
- {
- int n = -1;
- if (m_nodeList.count() > 0) {
- n = m_nodeList.first().number;
- }
- for (int i = 0; i < m_nodeList.count(); i++) {
- n = std::min(n, m_nodeList[i].number);
- }
- return n;
- }
|