diff options
| author | 2020-01-30 01:27:15 +0100 | |
|---|---|---|
| committer | 2020-03-28 02:05:05 +0100 | |
| commit | 653ba9395a36cc20ec1d68c9a9cae78973fa334c (patch) | |
| tree | 72753ed3bdca117baf001cdf8251b1fb22276eeb /node/mergenode.cpp | |
| parent | 22d71d0032e2f44a8f267895aea3bd87864791b3 (diff) | |
| download | OneRoll-653ba9395a36cc20ec1d68c9a9cae78973fa334c.tar.gz OneRoll-653ba9395a36cc20ec1d68c9a9cae78973fa334c.zip | |
add unicity and repeat function part2
Diffstat (limited to 'node/mergenode.cpp')
| -rw-r--r-- | node/mergenode.cpp | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/node/mergenode.cpp b/node/mergenode.cpp index 575613f..15f2fa7 100644 --- a/node/mergenode.cpp +++ b/node/mergenode.cpp @@ -40,25 +40,22 @@ void MergeNode::run(ExecutionNode* previous) for(auto start : *m_startList) { ExecutionNode* last= getLatestNode(start); - if(nullptr == last) + if(nullptr == last || nullptr == previousLast) continue; auto startResult= start->getResult(); if(nullptr == startResult) continue; - if(nullptr != previousLast) - { - startResult->setPrevious(previousLast->getResult()); - previousLast->setNextNode(start); - } + startResult->setPrevious(previousLast->getResult()); + previousLast->setNextNode(start); previousLast= last; Result* tmpResult= last->getResult(); while(nullptr != tmpResult) { DiceResult* dice= dynamic_cast<DiceResult*>(tmpResult); - if(nullptr != dice) + if(nullptr == dice) { ///@todo TODO improve here to set homogeneous while is really m_diceResult->setHomogeneous(false); |