Ref T252, updated CSettingsSimulatorBasicsComponent

* avoid saving default values
* use new specialized settings
This commit is contained in:
Klaus Basan
2018-02-16 03:36:36 +01:00
parent baa7f393ca
commit 82e42f7e17
3 changed files with 75 additions and 48 deletions

View File

@@ -9,6 +9,7 @@
#include "settingssimulatorbasicscomponent.h"
#include "ui_settingssimulatorbasicscomponent.h"
#include "blackmisc/simulation/xplane/xplaneutil.h"
#include "blackmisc/fileutils.h"
#include "blackmisc/logmessage.h"
#include "blackconfig/buildconfig.h"
@@ -19,6 +20,7 @@ using namespace BlackMisc;
using namespace BlackMisc::Simulation;
using namespace BlackMisc::Simulation::FsCommon;
using namespace BlackMisc::Simulation::Settings;
using namespace BlackMisc::Simulation::XPlane;
using namespace BlackConfig;
namespace BlackGui
@@ -48,9 +50,9 @@ namespace BlackGui
connect(ui->pb_CopyDefaults, &QPushButton::clicked, this, &CSettingsSimulatorBasicsComponent::copyDefaults);
connect(ui->pb_AdjustModelDirectory, &QPushButton::clicked, this, &CSettingsSimulatorBasicsComponent::adjustModelDirectory);
connect(ui->le_SimulatorDirectory, &QLineEdit::returnPressed, this, &CSettingsSimulatorBasicsComponent::simulatorDirectoryEntered);
connect(ui->comp_SimulatorSelector, &CSimulatorSelector::changed, this, &CSettingsSimulatorBasicsComponent::simulatorChanged);
connect(ui->comp_SimulatorSelector, &CSimulatorSelector::changed, this, &CSettingsSimulatorBasicsComponent::onSimulatorChanged);
this->simulatorChanged();
this->onSimulatorChanged();
}
CSettingsSimulatorBasicsComponent::~CSettingsSimulatorBasicsComponent()
@@ -76,7 +78,7 @@ namespace BlackGui
void CSettingsSimulatorBasicsComponent::simulatorFileDialog()
{
const QString startDirectory = this->getFileBrowserSimulatorDirectory();
const QString startDirectory = CFileUtils::fixWindowsUncPath(this->getFileBrowserSimulatorDirectory());
const QString dir = QFileDialog::getExistingDirectory(this, tr("Simulator directory"), startDirectory,
QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks);
if (dir.isEmpty()) { return; }
@@ -86,11 +88,11 @@ namespace BlackGui
void CSettingsSimulatorBasicsComponent::modelFileDialog()
{
const QString startDirectory = this->getFileBrowserModelDirectory();
const QString startDirectory = CFileUtils::fixWindowsUncPath(this->getFileBrowserModelDirectory());
const QString dir = QFileDialog::getExistingDirectory(this, tr("Model directory"), startDirectory,
QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks);
if (dir.isEmpty()) { return; }
const QStringList newDirs = this->addDirectory(dir, this->parseDirectories(ui->pte_ModelDirectories->toPlainText()));
const QStringList newDirs = this->addDirectory(dir, this->parseModelDirectories());
this->displayModelDirectories(newDirs);
}
@@ -100,7 +102,7 @@ namespace BlackGui
const QString dir = QFileDialog::getExistingDirectory(this, tr("Exclude directory"), startDirectory,
QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks);
if (dir.isEmpty()) { return; }
const QStringList newDirs = this->addDirectory(dir, this->parseDirectories(ui->pte_ExcludeDirectories->toPlainText()));
const QStringList newDirs = this->addDirectory(dir, this->parseModelDirectories());
this->displayExcludeDirectoryPatterns(newDirs);
}
@@ -115,9 +117,9 @@ namespace BlackGui
void CSettingsSimulatorBasicsComponent::save()
{
const CSimulatorInfo simulator(ui->comp_SimulatorSelector->getValue());
CSimulatorSettings s = this->getSettings(simulator);
CSimulatorSettings s = this->getSettings(simulator).getGenericSettings();
const QString simulatorDir(ui->le_SimulatorDirectory->text().trimmed());
const QStringList modelDirs(this->parseDirectories(ui->pte_ModelDirectories->toPlainText()));
const QStringList modelDirs(this->parseModelDirectories());
const QStringList excludeDirs(this->parseDirectories(ui->pte_ExcludeDirectories->toPlainText()));
const QStringList relativeDirs = CFileUtils::makeDirectoriesRelative(excludeDirs, this->getFileBrowserModelDirectory(), m_fileCaseSensitivity);
@@ -125,10 +127,7 @@ namespace BlackGui
s.setModelDirectories(modelDirs);
s.setModelExcludeDirectories(relativeDirs);
const CStatusMessage m = m_settings.setAndSaveSettings(s, simulator);
if (!m.isEmpty())
{
CLogMessage::preformatted(m);
}
if (!m.isEmpty()) { CLogMessage::preformatted(m); }
// display as saved
this->displaySettings(simulator);
@@ -137,37 +136,26 @@ namespace BlackGui
void CSettingsSimulatorBasicsComponent::copyDefaults()
{
const CSimulatorInfo simulator(ui->comp_SimulatorSelector->getValue());
const QString sd(m_settings.getDefaultSimulatorDirectory(simulator));
const QString sd(m_settings.defaultSimulatorDirectory(simulator));
ui->le_SimulatorDirectory->setText(CFileUtils::normalizeFilePathToQtStandard(sd));
const QStringList md(m_settings.getDefaultModelDirectories(simulator));
const QStringList md(m_settings.defaultModelDirectories(simulator));
this->displayModelDirectories(md);
const QStringList excludes(m_settings.getDefaultModelExcludeDirectoryPatterns(simulator));
const QStringList excludes(m_settings.defaultModelExcludeDirectoryPatterns(simulator));
this->displayExcludeDirectoryPatterns(excludes);
}
void CSettingsSimulatorBasicsComponent::adjustModelDirectory()
{
const CSimulatorInfo simulator(ui->comp_SimulatorSelector->getValue());
QString simDir = this->getFileBrowserSimulatorDirectory();
if (simulator.isFsxP3DFamily())
{
simDir = CFsCommonUtil::fsxSimObjectsDirFromSimDir(simDir);
}
else if (simulator.fs9())
{
simDir = CFsCommonUtil::fs9AircraftDirFromSimDir(simDir);
}
else if (simulator.xplane())
{
// There is not really a fixed place in the X-Plane install directory where models are put.
// We just treat the whole X-Plane directory as model directory and search for models in all subdirectories recursively.
}
else
{
return;
}
const QString simDir = this->getFileBrowserSimulatorDirectory();
CSpecializedSimulatorSettings s = m_settings.getSpecializedSettings(simulator);
s.setSimulatorDirectory(simDir);
const QStringList newDirs = this->addDirectory(simDir, this->parseDirectories(ui->pte_ModelDirectories->toPlainText()));
// There is not really a fixed place in the X-Plane install directory where models are put.
// We just treat the whole X-Plane directory as model directory and search for models in all subdirectories recursively.
const QStringList parsedDirectories = this->parseModelDirectories();
const QStringList newDirs = parsedDirectories.size() > 1 ? parsedDirectories : this->removeDirectories(s.getModelDirectoriesFromSimulatorDirectoryOrDefault(), parsedDirectories);
this->displayModelDirectories(newDirs);
}
@@ -183,11 +171,16 @@ namespace BlackGui
CLogMessage(this).info("Reset values for settings of %1") << simulator.toQString(true);
}
void CSettingsSimulatorBasicsComponent::simulatorChanged()
void CSettingsSimulatorBasicsComponent::onSimulatorChanged()
{
const CSimulatorInfo simulator(ui->comp_SimulatorSelector->getValue());
this->displayDefaultValuesAsPlaceholder(simulator);
this->displaySettings(simulator);
this->displayDefaultValuesAsPlaceholder(simulator);
}
QStringList CSettingsSimulatorBasicsComponent::parseModelDirectories() const
{
return this->parseDirectories(ui->pte_ModelDirectories->toPlainText());
}
QStringList CSettingsSimulatorBasicsComponent::parseDirectories(const QString &rawString) const
@@ -221,6 +214,27 @@ namespace BlackGui
return dirs;
}
QStringList CSettingsSimulatorBasicsComponent::removeDirectory(const QString &directory, const QStringList &existingDirs)
{
const QString d(CFileUtils::normalizeFilePathToQtStandard(directory));
return this->removeDirectories(QStringList({d}), existingDirs);
}
QStringList CSettingsSimulatorBasicsComponent::removeDirectories(const QStringList &removeDirectories, const QStringList &existingDirs)
{
if (existingDirs.isEmpty() || removeDirectories.isEmpty()) { return existingDirs; }
const QStringList rDirs = CFileUtils::fixWindowsUncPaths(removeDirectories);
QStringList dirs;
for (const QString &dir : existingDirs)
{
if (rDirs.contains(dir, m_fileCaseSensitivity)) { continue; }
dirs.push_back(dir);
}
dirs.removeDuplicates();
dirs.sort(m_fileCaseSensitivity);
return dirs;
}
void CSettingsSimulatorBasicsComponent::displayExcludeDirectoryPatterns(const QStringList &dirs)
{
QStringList cleanedDirs(dirs);
@@ -237,11 +251,12 @@ namespace BlackGui
cleanedDirs.sort(m_fileCaseSensitivity);
const QString d = cleanedDirs.join("\n");
ui->pte_ModelDirectories->setPlainText(d);
this->displayDefaultValuesAsPlaceholder(ui->comp_SimulatorSelector->getValue());
}
CSimulatorSettings CSettingsSimulatorBasicsComponent::getSettings(const CSimulatorInfo &simulator) const
CSpecializedSimulatorSettings CSettingsSimulatorBasicsComponent::getSettings(const CSimulatorInfo &simulator) const
{
const CSimulatorSettings s = m_settings.getSettings(simulator);
const CSpecializedSimulatorSettings s = m_settings.getSpecializedSettings(simulator);
return s;
}
@@ -254,12 +269,17 @@ namespace BlackGui
void CSettingsSimulatorBasicsComponent::displayDefaultValuesAsPlaceholder(const CSimulatorInfo &simulator)
{
const QString s = m_settings.getDefaultSimulatorDirectory(simulator);
ui->le_SimulatorDirectory->setPlaceholderText(s.isEmpty() ? "Simulator directory" : s);
const QString simDir = this->getFileBrowserSimulatorDirectory();
ui->le_SimulatorDirectory->setPlaceholderText(simDir.isEmpty() ? "Simulator directory" : simDir);
//! \fixme correct version when Qt multiline placeholder is fixed https://bugreports.qt.io/browse/QTBUG-43817
constexpr bool BrokenMultilinePlaceholder = true; // last checked with Qt 5.10
const QStringList m = m_settings.getDefaultModelDirectories(simulator);
// we take the settings and update to latest sim.directory
CSpecializedSimulatorSettings settings = m_settings.getSpecializedSettings(simulator);
settings.setSimulatorDirectory(simDir);
const QStringList m = settings.getModelDirectoriesFromSimulatorDirectoryOrDefault();
if (m.isEmpty())
{
ui->pte_ModelDirectories->setPlaceholderText("Model directories");
@@ -278,7 +298,7 @@ namespace BlackGui
}
}
const QStringList e = m_settings.getDefaultModelExcludeDirectoryPatterns(simulator);
const QStringList e = settings.getDefaultModelExcludeDirectoryPatterns();
if (e.isEmpty())
{
ui->pte_ExcludeDirectories->setPlaceholderText("Exclude directories");