summaryrefslogtreecommitdiffstats
path: root/sigscript/NatureWrapper.cpp
blob: e6af871854db4073c48e2f31978de8f7184af82b (plain)
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
/*
 * Copyright 2008 Ben Boeckel <MathStuf@gmail.com>
 * 
 * This program 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 3 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, see <http://www.gnu.org/licenses/>.
 */

// Header include
#include "NatureWrapper.h"

// Sigscript includes
#include "SigmodWrapper.h"

Sigscript::NatureWrapper* Sigscript::NatureWrapper::create(const Sigmod::Nature* nature, SigmodWrapper* parent)
{
    Signature sig = Signature(parent, Subsignature(nature->className(), nature->id()));
    if (!m_instances.contains(sig))
        m_instances[sig] = new NatureWrapper(nature, parent);
    return qobject_cast<NatureWrapper*>(m_instances[sig]);
}

Sigscript::NatureWrapper::NatureWrapper(const Sigmod::Nature* nature, SigmodWrapper* parent) :
        ObjectWrapper(nature, parent),
        m_nature(nature)
{
}

QString Sigscript::NatureWrapper::name() const
{
    return m_nature->name();
}

Sigcore::Fraction Sigscript::NatureWrapper::stat(const Sigmod::Stat stat) const
{
    return m_nature->stat(stat);
}

int Sigscript::NatureWrapper::weight() const
{
    return m_nature->weight();
}