diff options
| author | 2019-12-18 01:00:52 +0100 | |
|---|---|---|
| committer | 2019-12-22 01:19:23 +0100 | |
| commit | 60fb4821f883636dad9a404fd3d2fcdb0e48e10c (patch) | |
| tree | 84d2abafc41401e29d5bcc37b4c65d68830c4013 /node | |
| parent | 9538cf4d4c99e0b63e641b281970bb169166d42f (diff) | |
| download | OneRoll-60fb4821f883636dad9a404fd3d2fcdb0e48e10c.tar.gz OneRoll-60fb4821f883636dad9a404fd3d2fcdb0e48e10c.zip | |
Fix mergenode.cpp
Diffstat (limited to 'node')
| -rw-r--r-- | node/mergenode.cpp | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/node/mergenode.cpp b/node/mergenode.cpp index 15f2fa7..575613f 100644 --- a/node/mergenode.cpp +++ b/node/mergenode.cpp @@ -40,22 +40,25 @@ void MergeNode::run(ExecutionNode* previous) for(auto start : *m_startList) { ExecutionNode* last= getLatestNode(start); - if(nullptr == last || nullptr == previousLast) + if(nullptr == last) continue; auto startResult= start->getResult(); if(nullptr == startResult) continue; - startResult->setPrevious(previousLast->getResult()); - previousLast->setNextNode(start); + if(nullptr != previousLast) + { + 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); |