aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/src/libparser/result/result.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/libparser/result/result.cpp')
-rw-r--r--src/libparser/result/result.cpp86
1 files changed, 86 insertions, 0 deletions
diff --git a/src/libparser/result/result.cpp b/src/libparser/result/result.cpp
new file mode 100644
index 0000000..ca410b3
--- /dev/null
+++ b/src/libparser/result/result.cpp
@@ -0,0 +1,86 @@
+/***************************************************************************
+ * Copyright (C) 2014 by Renaud Guezennec *
+ * https://rolisteam.org/contact *
+ * *
+ * This file is part of DiceParser *
+ * *
+ * DiceParser is free software; you can redistribute it and/or modify *
+ * it under the terms of the GNU General Public License as published by *
+ * the Free Software Foundation; either version 2 of the License, or *
+ * (at your option) any later version. *
+ * *
+ * This program is distributed in the hope that it will be useful, *
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of *
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
+ * GNU General Public License for more details. *
+ * *
+ * You should have received a copy of the GNU General Public License *
+ * along with this program; if not, write to the *
+ * Free Software Foundation, Inc., *
+ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
+ ***************************************************************************/
+#include "result.h"
+#include <QUuid>
+
+Result::Result()
+ : m_resultTypes(static_cast<int>(Dice::RESULT_TYPE::NONE))
+ , m_id(QString("\"%1\"").arg(QUuid::createUuid().toString()))
+ , m_previous(nullptr)
+{
+}
+Result::~Result() {}
+
+Result* Result::getPrevious() const
+{
+ return m_previous;
+}
+
+void Result::setPrevious(Result* p)
+{
+ Q_ASSERT(p != this);
+ m_previous= p;
+}
+
+bool Result::isStringResult() const
+{
+ return false;
+}
+void Result::clear() {}
+bool Result::hasResultOfType(Dice::RESULT_TYPE type) const
+{
+ return (m_resultTypes & static_cast<int>(type));
+}
+void Result::generateDotTree(QString& s)
+{
+ auto str= toString(true);
+ if(s.contains(str))
+ return;
+ s.append(str);
+ s.append(";\n");
+
+ if(nullptr != m_previous)
+ {
+ s.append(toString(false));
+ s.append(" -> ");
+ s.append(m_previous->toString(false));
+ s.append("[label=\"previousResult\"]\n");
+ m_previous->generateDotTree(s);
+ }
+ else
+ {
+ s.append(toString(false));
+ s.append(" -> ");
+ s.append("nullptr");
+ s.append(" [label=\"previousResult\", shape=\"box\"];\n");
+ }
+}
+
+QString Result::getId() const
+{
+ return m_id;
+}
+
+QString Result::getStringResult() const
+{
+ return {};
+}