aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/node
diff options
context:
space:
mode:
authorRenaud G <renaud@rolisteam.org>2015-03-03 23:00:11 +0100
committerRenaud G <renaud@rolisteam.org>2015-03-03 23:00:11 +0100
commit30aaf7a35bc6e8224ad683148af28cedf81f03fd (patch)
tree4ef6e1451a62d852d4b83f2bb2a89e7940a33c6d /node
parent343f0d6b839d3f9a4740733cf2148b136ef8e00d (diff)
downloadOneRoll-30aaf7a35bc6e8224ad683148af28cedf81f03fd.tar.gz
OneRoll-30aaf7a35bc6e8224ad683148af28cedf81f03fd.zip
Add gui and new node.
Diffstat (limited to 'node')
-rw-r--r--node/jumpbackwardnode.cpp38
-rw-r--r--node/jumpbackwardnode.h27
2 files changed, 65 insertions, 0 deletions
diff --git a/node/jumpbackwardnode.cpp b/node/jumpbackwardnode.cpp
new file mode 100644
index 0000000..c311ed2
--- /dev/null
+++ b/node/jumpbackwardnode.cpp
@@ -0,0 +1,38 @@
+#include "jumpbackwardnode.h"
+
+JumpBackwardNode::JumpBackwardNode()
+{
+}
+
+
+
+qint64 JumpBackwardNode::getPriority() const
+{
+ return 1;
+}
+QString JumpBackwardNode::toString() const
+{
+ return QString();
+}
+void JumpBackwardNode::run(ExecutionNode* previous)
+{
+ ExecutionNode* parent = previous;
+ bool found=false;
+ int i = 1;
+ Result* result=NULL;
+ while((NULL!=parent)&&(found))
+ {
+ result = parent->getResult();
+ if(NULL!=result)
+ {
+ --i;
+ if(i==0)
+ {
+ found =true;
+ }
+ }
+ parent = parent->getPreviousNode();
+
+ }
+ m_result = result;
+}
diff --git a/node/jumpbackwardnode.h b/node/jumpbackwardnode.h
new file mode 100644
index 0000000..d211385
--- /dev/null
+++ b/node/jumpbackwardnode.h
@@ -0,0 +1,27 @@
+#ifndef JUMPBACKWARDNODE_H
+#define JUMPBACKWARDNODE_H
+
+#include "executionnode.h"
+
+class JumpBackwardNode : public ExecutionNode
+{
+public:
+ JumpBackwardNode();
+
+ virtual void run(ExecutionNode* previous = NULL);
+
+ /**
+ * @brief toString
+ * @return
+ */
+ virtual QString toString() const;
+ /**
+ * @brief getPriority
+ * @return
+ */
+ virtual qint64 getPriority() const;
+
+
+};
+
+#endif // JUMPBACKWARDNODE_H