summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew <forkk@forkk.net>2013-02-18 16:58:53 -0600
committerAndrew <forkk@forkk.net>2013-02-18 16:58:53 -0600
commit80cd8b33aa12933392bd2293a5e91ae696dbe6be (patch)
tree9311cb01fbecfc005ef17a4aef98c026004d5fff
parentd3c4db8f3444c8531cb5a02ce3c95d5673ffb1a5 (diff)
downloadMultiMC-80cd8b33aa12933392bd2293a5e91ae696dbe6be.tar
MultiMC-80cd8b33aa12933392bd2293a5e91ae696dbe6be.tar.gz
MultiMC-80cd8b33aa12933392bd2293a5e91ae696dbe6be.tar.lz
MultiMC-80cd8b33aa12933392bd2293a5e91ae696dbe6be.tar.xz
MultiMC-80cd8b33aa12933392bd2293a5e91ae696dbe6be.zip
Implemented Instance
-rw-r--r--data/inst/instance.cpp34
-rw-r--r--data/inst/instanceloader.cpp5
-rw-r--r--data/inst/instanceloader.h2
3 files changed, 38 insertions, 3 deletions
diff --git a/data/inst/instance.cpp b/data/inst/instance.cpp
index d2240bc5..8561ed9f 100644
--- a/data/inst/instance.cpp
+++ b/data/inst/instance.cpp
@@ -15,7 +15,41 @@
#include "instance.h"
+#include <QFileInfo>
+
+#include "util/pathutils.h"
+
Instance::Instance(const QString &rootDir, QObject *parent) :
SettingsBase(parent)
{
+ m_rootDir = rootDir;
+ config.loadFile(PathCombine(rootDir, "instance.cfg"));
+}
+
+QString Instance::id()
+{
+ return QFileInfo(rootDir()).baseName();
+}
+
+QString Instance::rootDir()
+{
+ return m_rootDir;
+}
+
+InstanceList *Instance::instList()
+{
+ if (parent()->inherits("InstanceList"))
+ return (InstanceList *)parent();
+ else
+ return NULL;
+}
+
+QVariant Instance::getField(const QString &name, QVariant defVal) const
+{
+ return config.get(name, defVal);
+}
+
+void Instance::setField(const QString &name, QVariant val)
+{
+ config.set(name, val);
}
diff --git a/data/inst/instanceloader.cpp b/data/inst/instanceloader.cpp
index bc43c061..1a53bfa7 100644
--- a/data/inst/instanceloader.cpp
+++ b/data/inst/instanceloader.cpp
@@ -17,9 +17,10 @@
#include "instancetype.h"
-InstanceLoader::InstanceLoader(QObject *parent) :
- QObject(parent)
+InstanceLoader::InstanceLoader() :
+ QObject(NULL)
{
+
}
diff --git a/data/inst/instanceloader.h b/data/inst/instanceloader.h
index 1a8a598f..b7092edc 100644
--- a/data/inst/instanceloader.h
+++ b/data/inst/instanceloader.h
@@ -109,7 +109,7 @@ public:
InstTypeList typeList();
private:
- explicit InstanceLoader(QObject *parent = 0);
+ InstanceLoader();
QMap<QString, InstanceType *> m_typeMap;
};