184 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			184 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/* Copyright 2013-2015 MultiMC Contributors
 | 
						|
 *
 | 
						|
 * Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
 * you may not use this file except in compliance with the License.
 | 
						|
 * You may obtain a copy of the License at
 | 
						|
 *
 | 
						|
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
 *
 | 
						|
 * Unless required by applicable law or agreed to in writing, software
 | 
						|
 * distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
 * See the License for the specific language governing permissions and
 | 
						|
 * limitations under the License.
 | 
						|
 */
 | 
						|
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include <QObject>
 | 
						|
#include <QAbstractListModel>
 | 
						|
#include <QSet>
 | 
						|
 | 
						|
#include "BaseInstance.h"
 | 
						|
 | 
						|
class BaseInstance;
 | 
						|
class QDir;
 | 
						|
 | 
						|
class InstanceList : public QAbstractListModel
 | 
						|
{
 | 
						|
	Q_OBJECT
 | 
						|
private:
 | 
						|
	void loadGroupList(QMap<QString, QString> &groupList);
 | 
						|
 | 
						|
public
 | 
						|
slots:
 | 
						|
	void saveGroupList();
 | 
						|
 | 
						|
public:
 | 
						|
	explicit InstanceList(SettingsObjectPtr globalSettings, const QString &instDir, QObject *parent = 0);
 | 
						|
	virtual ~InstanceList();
 | 
						|
 | 
						|
public:
 | 
						|
	QModelIndex index(int row, int column = 0, const QModelIndex &parent = QModelIndex()) const;
 | 
						|
	int rowCount(const QModelIndex &parent = QModelIndex()) const;
 | 
						|
	QVariant data(const QModelIndex &index, int role) const;
 | 
						|
	Qt::ItemFlags flags(const QModelIndex &index) const;
 | 
						|
 | 
						|
	enum AdditionalRoles
 | 
						|
	{
 | 
						|
		GroupRole = Qt::UserRole,
 | 
						|
		InstancePointerRole = 0x34B1CB48, ///< Return pointer to real instance
 | 
						|
		InstanceIDRole = 0x34B1CB49 ///< Return id if the instance
 | 
						|
	};
 | 
						|
	/*!
 | 
						|
	 * \brief Error codes returned by functions in the InstanceList class.
 | 
						|
	 * NoError Indicates that no error occurred.
 | 
						|
	 * UnknownError indicates that an unspecified error occurred.
 | 
						|
	 */
 | 
						|
	enum InstListError
 | 
						|
	{
 | 
						|
		NoError = 0,
 | 
						|
		UnknownError
 | 
						|
	};
 | 
						|
 | 
						|
	enum InstLoadError
 | 
						|
	{
 | 
						|
		NoLoadError = 0,
 | 
						|
		UnknownLoadError,
 | 
						|
		NotAnInstance
 | 
						|
	};
 | 
						|
 | 
						|
	enum InstCreateError
 | 
						|
	{
 | 
						|
		NoCreateError = 0,
 | 
						|
		NoSuchVersion,
 | 
						|
		UnknownCreateError,
 | 
						|
		InstExists,
 | 
						|
		CantCreateDir
 | 
						|
	};
 | 
						|
 | 
						|
	QString instDir() const
 | 
						|
	{
 | 
						|
		return m_instDir;
 | 
						|
	}
 | 
						|
 | 
						|
	/*!
 | 
						|
	 * \brief Get the instance at index
 | 
						|
	 */
 | 
						|
	InstancePtr at(int i) const
 | 
						|
	{
 | 
						|
		return m_instances.at(i);
 | 
						|
	}
 | 
						|
	;
 | 
						|
 | 
						|
	/*!
 | 
						|
	 * \brief Get the count of loaded instances
 | 
						|
	 */
 | 
						|
	int count() const
 | 
						|
	{
 | 
						|
		return m_instances.count();
 | 
						|
	}
 | 
						|
	;
 | 
						|
 | 
						|
	/// Clear all instances. Triggers notifications.
 | 
						|
	void clear();
 | 
						|
 | 
						|
	/// Add an instance. Triggers notifications, returns the new index
 | 
						|
	int add(InstancePtr t);
 | 
						|
 | 
						|
	/// Get an instance by ID
 | 
						|
	InstancePtr getInstanceById(QString id) const;
 | 
						|
 | 
						|
	QModelIndex getInstanceIndexById(const QString &id) const;
 | 
						|
 | 
						|
	// FIXME: instead of iterating through all instances and forming a set, keep the set around
 | 
						|
	QStringList getGroups();
 | 
						|
 | 
						|
	/*!
 | 
						|
	 * \brief Creates a stub instance
 | 
						|
	 *
 | 
						|
	 * \param inst Pointer to store the created instance in.
 | 
						|
	 * \param version Game version to use for the instance
 | 
						|
	 * \param instDir The new instance's directory.
 | 
						|
	 * \return An InstCreateError error code.
 | 
						|
	 * - InstExists if the given instance directory is already an instance.
 | 
						|
	 * - CantCreateDir if the given instance directory cannot be created.
 | 
						|
	 */
 | 
						|
	InstCreateError createInstance(InstancePtr &inst, BaseVersionPtr version,
 | 
						|
								   const QString &instDir);
 | 
						|
 | 
						|
	/*!
 | 
						|
	 * \brief Creates a copy of an existing instance with a new name
 | 
						|
	 *
 | 
						|
	 * \param newInstance Pointer to store the created instance in.
 | 
						|
	 * \param oldInstance The instance to copy
 | 
						|
	 * \param instDir The new instance's directory.
 | 
						|
	 * \return An InstCreateError error code.
 | 
						|
	 * - InstExists if the given instance directory is already an instance.
 | 
						|
	 * - CantCreateDir if the given instance directory cannot be created.
 | 
						|
	 */
 | 
						|
	InstCreateError copyInstance(InstancePtr &newInstance, InstancePtr &oldInstance,
 | 
						|
								 const QString &instDir);
 | 
						|
 | 
						|
	/*!
 | 
						|
	 * \brief Loads an instance from the given directory.
 | 
						|
	 * Checks the instance's INI file to figure out what the instance's type is first.
 | 
						|
	 * \param inst Pointer to store the loaded instance in.
 | 
						|
	 * \param instDir The instance's directory.
 | 
						|
	 * \return An InstLoadError error code.
 | 
						|
	 * - NotAnInstance if the given instance directory isn't a valid instance.
 | 
						|
	 */
 | 
						|
	InstLoadError loadInstance(InstancePtr &inst, const QString &instDir);
 | 
						|
 | 
						|
signals:
 | 
						|
	void dataIsInvalid();
 | 
						|
 | 
						|
public
 | 
						|
slots:
 | 
						|
	void on_InstFolderChanged(const Setting &setting, QVariant value);
 | 
						|
 | 
						|
	/*!
 | 
						|
	 * \brief Loads the instance list. Triggers notifications.
 | 
						|
	 */
 | 
						|
	InstListError loadList();
 | 
						|
 | 
						|
private
 | 
						|
slots:
 | 
						|
	void propertiesChanged(BaseInstance *inst);
 | 
						|
	void instanceNuked(BaseInstance *inst);
 | 
						|
	void groupChanged();
 | 
						|
 | 
						|
private:
 | 
						|
	int getInstIndex(BaseInstance *inst) const;
 | 
						|
 | 
						|
public:
 | 
						|
	static bool continueProcessInstance(InstancePtr instPtr, const int error, const QDir &dir,
 | 
						|
								 QMap<QString, QString> &groupMap);
 | 
						|
 | 
						|
protected:
 | 
						|
	QString m_instDir;
 | 
						|
	QList<InstancePtr> m_instances;
 | 
						|
	QSet<QString> m_groups;
 | 
						|
	SettingsObjectPtr m_globalSettings;
 | 
						|
};
 |