aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/node/listaliasnode.cpp
blob: 642f6012c76ee51ee296bd2adf0ca076131c64f9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*************************************************************************
 *   Copyright (C) 2009 by Renaud Guezennec                              *
 *                                                                       *
 *   http://www.rolisteam.org/                                           *
 *                                                                       *
 *   rolisteam 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 "listaliasnode.h"

ListAliasNode::ListAliasNode(QList<DiceAlias*>* apAlias)
    : m_aliasList(apAlias)
{
	m_result = new StringResult();
}
void ListAliasNode::run(ExecutionNode* previous )
{
	m_previousNode = previous;
	StringResult* txtResult = dynamic_cast<StringResult*>(m_result);
    txtResult->setHighLight(false);

	if(nullptr != previous)
	{
		if(previous->getResult() == nullptr)
		{
            txtResult->setText(buildList());

		}
		else
		{
			txtResult->setText(previous->getHelp());
		}
		m_result->setPrevious(previous->getResult());
	}

	if(nullptr!=m_nextNode)
	{
		m_nextNode->run(this);
	}
}
QString ListAliasNode::buildList() const
{
	QString result(QObject::tr("List of Alias:\n"));
    foreach(DiceAlias* key, *m_aliasList)
	{
        result+=QString("%1 : %2\n").arg(key->getCommand()).arg(key->getValue());
	}
	return result;
}
QString ListAliasNode::toString(bool wl) const
{
	QStringList resultList;
	foreach(DiceAlias* key, *m_aliasList)
	{
		resultList <<  "{" <<key->getCommand() << key->getValue()<<  "}";
	}

	if(wl)
	{
		return QString("%1 [label=\"ListAliasNode %2\"]").arg(m_id).arg(resultList.join(","));
	}
	else
	{
		return m_id;
	}
}
qint64 ListAliasNode::getPriority() const
{
	return 0;
}

ExecutionNode* ListAliasNode::getCopy() const
{
    ListAliasNode* node = new ListAliasNode(m_aliasList);
    if(nullptr!=m_nextNode)
    {
        node->setNextNode(m_nextNode->getCopy());
    }
    return node;

}