diff options
| author | 2022-04-29 10:48:09 +0200 | |
|---|---|---|
| committer | 2022-04-29 10:48:09 +0200 | |
| commit | 07c5f6ec23fcf9237a24e71adcfacabce677f818 (patch) | |
| tree | 588e8c5f82b9163181fad3581f610e6f1d88cba4 /src/libparser/node/countexecutenode.cpp | |
| parent | a9153f1615a842cfb9e9bcda4d9071e202618569 (diff) | |
| download | OneRoll-07c5f6ec23fcf9237a24e71adcfacabce677f818.tar.gz OneRoll-07c5f6ec23fcf9237a24e71adcfacabce677f818.zip | |
Change file organization.
Diffstat (limited to 'src/libparser/node/countexecutenode.cpp')
| -rw-r--r-- | src/libparser/node/countexecutenode.cpp | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/src/libparser/node/countexecutenode.cpp b/src/libparser/node/countexecutenode.cpp new file mode 100644 index 0000000..b45fe37 --- /dev/null +++ b/src/libparser/node/countexecutenode.cpp @@ -0,0 +1,76 @@ +#include "countexecutenode.h" +#include "result/diceresult.h" +#include "validatorlist.h" + +CountExecuteNode::CountExecuteNode() : m_scalarResult(new ScalarResult()), m_validatorList(nullptr) +{ + m_result= m_scalarResult; +} +void CountExecuteNode::setValidatorList(ValidatorList* validatorlist) +{ + m_validatorList= validatorlist; +} +CountExecuteNode::~CountExecuteNode() +{ + if(nullptr != m_validatorList) + { + delete m_validatorList; + } +} + +void CountExecuteNode::run(ExecutionNode* previous) +{ + m_previousNode= previous; + if(nullptr == previous) + { + m_errors.insert(Dice::ERROR_CODE::NO_PREVIOUS_ERROR, QStringLiteral("No scalar result before Swith/Case operator")); + return; + } + DiceResult* previousResult= dynamic_cast<DiceResult*>(previous->getResult()); + if(nullptr != previousResult) + { + m_result->setPrevious(previousResult); + qint64 sum= 0; + std::function<void(Die*, qint64)> f= [&sum](const Die*, qint64 score) { sum+= score; }; + m_validatorList->validResult(previousResult, true, true, f); + m_scalarResult->setValue(sum); + if(nullptr != m_nextNode) + { + m_nextNode->run(this); + } + } +} +QString CountExecuteNode::toString(bool withlabel) const +{ + if(withlabel) + { + return QString("%1 [label=\"CountExecuteNode %2\"]").arg(m_id, m_validatorList->toString()); + } + else + { + return m_id; + } +} +qint64 CountExecuteNode::getPriority() const +{ + qint64 priority= 0; + if(nullptr != m_previousNode) + { + priority= m_previousNode->getPriority(); + } + return priority; +} + +ExecutionNode* CountExecuteNode::getCopy() const +{ + CountExecuteNode* node= new CountExecuteNode(); + if(nullptr != m_validatorList) + { + node->setValidatorList(m_validatorList->getCopy()); + } + if(nullptr != m_nextNode) + { + node->setNextNode(m_nextNode->getCopy()); + } + return node; +} |