mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-20 02:23:51 +00:00
Added writing masters/plugins to openmw.cfg
This commit is contained in:
parent
178cf2154e
commit
bcf4f96209
3 changed files with 18 additions and 22 deletions
|
@ -57,7 +57,6 @@ DataFilesPage::DataFilesPage(Files::ConfigurationManager &cfg, GameSettings &gam
|
||||||
{
|
{
|
||||||
// Models
|
// Models
|
||||||
mDataFilesModel = new DataFilesModel(this);
|
mDataFilesModel = new DataFilesModel(this);
|
||||||
mDataFilesModel->setObjectName(QString("mDataFilesModel"));
|
|
||||||
|
|
||||||
mMastersProxyModel = new QSortFilterProxyModel();
|
mMastersProxyModel = new QSortFilterProxyModel();
|
||||||
mMastersProxyModel->setFilterRegExp(QString("^.*\\.esm"));
|
mMastersProxyModel->setFilterRegExp(QString("^.*\\.esm"));
|
||||||
|
@ -65,14 +64,11 @@ DataFilesPage::DataFilesPage(Files::ConfigurationManager &cfg, GameSettings &gam
|
||||||
mMastersProxyModel->setSourceModel(mDataFilesModel);
|
mMastersProxyModel->setSourceModel(mDataFilesModel);
|
||||||
|
|
||||||
mPluginsProxyModel = new QSortFilterProxyModel();
|
mPluginsProxyModel = new QSortFilterProxyModel();
|
||||||
mPluginsProxyModel->setObjectName(QString("mPluginsProxyModel"));
|
|
||||||
mPluginsProxyModel->setFilterRegExp(QString("^.*\\.esp"));
|
mPluginsProxyModel->setFilterRegExp(QString("^.*\\.esp"));
|
||||||
mPluginsProxyModel->setFilterCaseSensitivity(Qt::CaseInsensitive);
|
mPluginsProxyModel->setFilterCaseSensitivity(Qt::CaseInsensitive);
|
||||||
mPluginsProxyModel->setSourceModel(mDataFilesModel);
|
mPluginsProxyModel->setSourceModel(mDataFilesModel);
|
||||||
|
|
||||||
mFilterProxyModel = new QSortFilterProxyModel();
|
mFilterProxyModel = new QSortFilterProxyModel();
|
||||||
mFilterProxyModel->setObjectName(QString("mFilterProxyModel"));
|
|
||||||
|
|
||||||
mFilterProxyModel->setDynamicSortFilter(true);
|
mFilterProxyModel->setDynamicSortFilter(true);
|
||||||
mFilterProxyModel->setSourceModel(mPluginsProxyModel);
|
mFilterProxyModel->setSourceModel(mPluginsProxyModel);
|
||||||
|
|
||||||
|
@ -155,7 +151,6 @@ DataFilesPage::DataFilesPage(Files::ConfigurationManager &cfg, GameSettings &gam
|
||||||
QList<int> sizeList;
|
QList<int> sizeList;
|
||||||
sizeList << mLauncherSettings.value(QString("General/MastersTable/width"), QString("200")).toInt();
|
sizeList << mLauncherSettings.value(QString("General/MastersTable/width"), QString("200")).toInt();
|
||||||
sizeList << mLauncherSettings.value(QString("General/PluginTable/width"), QString("340")).toInt();
|
sizeList << mLauncherSettings.value(QString("General/PluginTable/width"), QString("340")).toInt();
|
||||||
qDebug() << sizeList;
|
|
||||||
|
|
||||||
mSplitter->setSizes(sizeList);
|
mSplitter->setSizes(sizeList);
|
||||||
|
|
||||||
|
@ -279,20 +274,15 @@ void DataFilesPage::setupDataFiles()
|
||||||
|
|
||||||
void DataFilesPage::loadSettings()
|
void DataFilesPage::loadSettings()
|
||||||
{
|
{
|
||||||
qDebug() << "load settings";
|
|
||||||
QString profile = mLauncherSettings.value(QString("Profiles/CurrentProfile"));
|
QString profile = mLauncherSettings.value(QString("Profiles/CurrentProfile"));
|
||||||
|
|
||||||
qDebug() << mLauncherSettings.values(QString("Profiles/Default"), Qt::MatchStartsWith);
|
|
||||||
|
|
||||||
if (profile.isEmpty())
|
if (profile.isEmpty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
||||||
mDataFilesModel->uncheckAll();
|
mDataFilesModel->uncheckAll();
|
||||||
|
|
||||||
QStringList masters = mLauncherSettings.values(QString("Profiles/") + profile + QString("/master"), Qt::MatchExactly);
|
QStringList masters = mLauncherSettings.values(QString("Profiles/") + profile + QString("/master"), Qt::MatchExactly);
|
||||||
QStringList plugins = mLauncherSettings.values(QString("Profiles/") + profile + QString("/plugin"), Qt::MatchExactly);
|
QStringList plugins = mLauncherSettings.values(QString("Profiles/") + profile + QString("/plugin"), Qt::MatchExactly);
|
||||||
qDebug() << "masters to check " << plugins;
|
|
||||||
|
|
||||||
foreach (const QString &master, masters) {
|
foreach (const QString &master, masters) {
|
||||||
QModelIndex index = mDataFilesModel->indexFromItem(mDataFilesModel->findItem(master));
|
QModelIndex index = mDataFilesModel->indexFromItem(mDataFilesModel->findItem(master));
|
||||||
|
@ -316,21 +306,23 @@ void DataFilesPage::saveSettings()
|
||||||
mLauncherSettings.setValue(QString("Profiles/CurrentProfile"), profile);
|
mLauncherSettings.setValue(QString("Profiles/CurrentProfile"), profile);
|
||||||
}
|
}
|
||||||
|
|
||||||
qDebug() << "save settings" << profile;
|
|
||||||
mLauncherSettings.remove(QString("Profiles/") + profile + QString("/master"));
|
mLauncherSettings.remove(QString("Profiles/") + profile + QString("/master"));
|
||||||
mLauncherSettings.remove(QString("Profiles/") + profile + QString("/plugin"));
|
mLauncherSettings.remove(QString("Profiles/") + profile + QString("/plugin"));
|
||||||
|
|
||||||
|
mGameSettings.remove(QString("master"));
|
||||||
|
mGameSettings.remove(QString("plugin"));
|
||||||
|
|
||||||
QStringList items = mDataFilesModel->checkedItems();
|
QStringList items = mDataFilesModel->checkedItems();
|
||||||
|
|
||||||
foreach(const QString &item, items) {
|
foreach(const QString &item, items) {
|
||||||
|
|
||||||
if (item.endsWith(QString(".esm"), Qt::CaseInsensitive)) {
|
if (item.endsWith(QString(".esm"), Qt::CaseInsensitive)) {
|
||||||
qDebug() << "setting " << item;
|
|
||||||
mLauncherSettings.setMultiValue(QString("Profiles/") + profile + QString("/master"), item);
|
mLauncherSettings.setMultiValue(QString("Profiles/") + profile + QString("/master"), item);
|
||||||
|
mGameSettings.setMultiValue(QString("master"), item);
|
||||||
|
|
||||||
} else if (item.endsWith(QString(".esp"), Qt::CaseInsensitive)) {
|
} else if (item.endsWith(QString(".esp"), Qt::CaseInsensitive)) {
|
||||||
qDebug() << "setting " << item;
|
|
||||||
mLauncherSettings.setMultiValue(QString("Profiles/") + profile + QString("/plugin"), item);
|
mLauncherSettings.setMultiValue(QString("Profiles/") + profile + QString("/plugin"), item);
|
||||||
|
mGameSettings.setMultiValue(QString("plugin"), item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -500,7 +492,6 @@ void DataFilesPage::filterChanged(const QString filter)
|
||||||
|
|
||||||
void DataFilesPage::profileChanged(const QString &previous, const QString ¤t)
|
void DataFilesPage::profileChanged(const QString &previous, const QString ¤t)
|
||||||
{
|
{
|
||||||
qDebug() << "Profile is changed from: " << previous << " to " << current;
|
|
||||||
// Prevent the deletion of the default profile
|
// Prevent the deletion of the default profile
|
||||||
if (current == QLatin1String("Default")) {
|
if (current == QLatin1String("Default")) {
|
||||||
mDeleteProfileAction->setEnabled(false);
|
mDeleteProfileAction->setEnabled(false);
|
||||||
|
@ -527,7 +518,6 @@ void DataFilesPage::profileChanged(const QString &previous, const QString &curre
|
||||||
|
|
||||||
void DataFilesPage::profileRenamed(const QString &previous, const QString ¤t)
|
void DataFilesPage::profileRenamed(const QString &previous, const QString ¤t)
|
||||||
{
|
{
|
||||||
qDebug() << "rename";
|
|
||||||
if (previous.isEmpty())
|
if (previous.isEmpty())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -577,7 +567,6 @@ void DataFilesPage::showContextMenu(const QPoint &point)
|
||||||
: mCheckAction->setEnabled(true);
|
: mCheckAction->setEnabled(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Show menu
|
// Show menu
|
||||||
mContextMenu->exec(globalPos);
|
mContextMenu->exec(globalPos);
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,18 @@ public:
|
||||||
mSettings.insert(key, value);
|
mSettings.insert(key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline void setMultiValue(const QString &key, const QString &value)
|
||||||
|
{
|
||||||
|
QStringList values = mSettings.values(key);
|
||||||
|
if (!values.contains(value))
|
||||||
|
mSettings.insertMulti(key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void remove(const QString &key)
|
||||||
|
{
|
||||||
|
mSettings.remove(key);
|
||||||
|
}
|
||||||
|
|
||||||
inline QStringList getDataDirs() { return mDataDirs; }
|
inline QStringList getDataDirs() { return mDataDirs; }
|
||||||
inline void addDataDir(const QString &dir) { if(!dir.isEmpty()) mDataDirs.append(dir); }
|
inline void addDataDir(const QString &dir) { if(!dir.isEmpty()) mDataDirs.append(dir); }
|
||||||
inline QString getDataLocal() {return mDataLocal; }
|
inline QString getDataLocal() {return mDataLocal; }
|
||||||
|
|
|
@ -32,15 +32,10 @@ public:
|
||||||
inline void setMultiValue(const QString &key, const QString &value)
|
inline void setMultiValue(const QString &key, const QString &value)
|
||||||
{
|
{
|
||||||
QStringList values = mSettings.values(key);
|
QStringList values = mSettings.values(key);
|
||||||
if (!values.contains(value)) {
|
if (!values.contains(value))
|
||||||
qDebug() << "inserting " << value;
|
|
||||||
mSettings.insertMulti(key, value);
|
mSettings.insertMulti(key, value);
|
||||||
} else {
|
|
||||||
qDebug() << "not inserting " << value;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
inline void remove(const QString &key)
|
inline void remove(const QString &key)
|
||||||
{
|
{
|
||||||
mSettings.remove(key);
|
mSettings.remove(key);
|
||||||
|
|
Loading…
Reference in a new issue