PrismLauncher/depends/settings/inisettingsobject.h

64 lines
1.5 KiB
C
Raw Normal View History

2013-02-25 22:36:27 +00:00
/* Copyright 2013 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
*
2013-02-25 22:36:27 +00:00
* 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
2013-02-25 22:36:27 +00:00
#include <QObject>
2013-02-26 22:47:39 +00:00
#include "inifile.h"
2013-02-25 22:36:27 +00:00
#include "settingsobject.h"
#include "libsettings_config.h"
2013-02-25 22:36:27 +00:00
/*!
* \brief A settings object that stores its settings in an INIFile.
*/
2013-02-26 22:47:39 +00:00
class LIBSETTINGS_EXPORT INISettingsObject : public SettingsObject
2013-02-25 22:36:27 +00:00
{
Q_OBJECT
public:
explicit INISettingsObject(const QString &path, QObject *parent = 0);
2013-02-25 22:36:27 +00:00
/*!
* \brief Gets the path to the INI file.
* \return The path to the INI file.
*/
virtual QString filePath() const
{
return m_filePath;
}
2013-02-25 22:36:27 +00:00
/*!
* \brief Sets the path to the INI file and reloads it.
* \param filePath The INI file's new path.
*/
virtual void setFilePath(const QString &filePath);
bool reload() override;
protected
slots:
2013-02-25 22:36:27 +00:00
virtual void changeSetting(const Setting &setting, QVariant value);
virtual void resetSetting(const Setting &setting);
2013-02-25 22:36:27 +00:00
protected:
virtual QVariant retrieveValue(const Setting &setting);
2013-02-25 22:36:27 +00:00
INIFile m_ini;
2013-02-25 22:36:27 +00:00
QString m_filePath;
};