Utils: Use more FilePath in TerminalCommand

Change-Id: Ide9a09f61f3b2c10378d90a4a907e1e37d7407df
Reviewed-by: Eike Ziller <eike.ziller@qt.io>
Reviewed-by: <github-actions-qt-creator@cristianadam.eu>
Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org>
This commit is contained in:
hjk
2023-02-07 17:19:01 +01:00
parent 49561eaeb8
commit 85bed557f3
5 changed files with 22 additions and 18 deletions

View File

@@ -15,7 +15,7 @@ namespace Utils {
static QSettings *s_settings = nullptr; static QSettings *s_settings = nullptr;
TerminalCommand::TerminalCommand(const QString &command, const QString &openArgs, TerminalCommand::TerminalCommand(const FilePath &command, const QString &openArgs,
const QString &executeArgs, bool needsQuotes) const QString &executeArgs, bool needsQuotes)
: command(command) : command(command)
, openArgs(openArgs) , openArgs(openArgs)
@@ -65,9 +65,9 @@ TerminalCommand TerminalCommand::defaultTerminalEmulator()
if (defaultTerm.command.isEmpty()) { if (defaultTerm.command.isEmpty()) {
if (HostOsInfo::isMacHost()) { if (HostOsInfo::isMacHost()) {
const QString termCmd = QCoreApplication::applicationDirPath() const FilePath termCmd = FilePath::fromString(QCoreApplication::applicationDirPath())
+ "/../Resources/scripts/openTerminal.py"; / "../Resources/scripts/openTerminal.py";
if (QFileInfo::exists(termCmd)) if (termCmd.exists())
defaultTerm = {termCmd, "", ""}; defaultTerm = {termCmd, "", ""};
else else
defaultTerm = {"/usr/X11/bin/xterm", "", "-e"}; defaultTerm = {"/usr/X11/bin/xterm", "", "-e"};
@@ -76,7 +76,7 @@ TerminalCommand TerminalCommand::defaultTerminalEmulator()
defaultTerm = {"xterm", "", "-e"}; defaultTerm = {"xterm", "", "-e"};
const Environment env = Environment::systemEnvironment(); const Environment env = Environment::systemEnvironment();
for (const TerminalCommand &term : *knownTerminals) { for (const TerminalCommand &term : *knownTerminals) {
const QString result = env.searchInPath(term.command).toString(); const FilePath result = env.searchInPath(term.command.path());
if (!result.isEmpty()) { if (!result.isEmpty()) {
defaultTerm = {result, term.openArgs, term.executeArgs, term.needsQuotes}; defaultTerm = {result, term.openArgs, term.executeArgs, term.needsQuotes};
break; break;
@@ -95,7 +95,7 @@ QVector<TerminalCommand> TerminalCommand::availableTerminalEmulators()
if (HostOsInfo::isAnyUnixHost()) { if (HostOsInfo::isAnyUnixHost()) {
const Environment env = Environment::systemEnvironment(); const Environment env = Environment::systemEnvironment();
for (const TerminalCommand &term : *knownTerminals) { for (const TerminalCommand &term : *knownTerminals) {
const QString command = env.searchInPath(term.command).toString(); const FilePath command = env.searchInPath(term.command.path());
if (!command.isEmpty()) if (!command.isEmpty())
result.push_back({command, term.openArgs, term.executeArgs}); result.push_back({command, term.openArgs, term.executeArgs});
} }
@@ -118,7 +118,7 @@ const char kTerminalExecuteOptionsKey[] = "General/Terminal/ExecuteOptions";
TerminalCommand TerminalCommand::terminalEmulator() TerminalCommand TerminalCommand::terminalEmulator()
{ {
if (s_settings && HostOsInfo::isAnyUnixHost() && s_settings->contains(kTerminalCommandKey)) { if (s_settings && HostOsInfo::isAnyUnixHost() && s_settings->contains(kTerminalCommandKey)) {
return {s_settings->value(kTerminalCommandKey).toString(), return {FilePath::fromSettings(s_settings->value(kTerminalCommandKey)),
s_settings->value(kTerminalOpenOptionsKey).toString(), s_settings->value(kTerminalOpenOptionsKey).toString(),
s_settings->value(kTerminalExecuteOptionsKey).toString()}; s_settings->value(kTerminalExecuteOptionsKey).toString()};
} }
@@ -135,7 +135,7 @@ void TerminalCommand::setTerminalEmulator(const TerminalCommand &term)
s_settings->remove(kTerminalOpenOptionsKey); s_settings->remove(kTerminalOpenOptionsKey);
s_settings->remove(kTerminalExecuteOptionsKey); s_settings->remove(kTerminalExecuteOptionsKey);
} else { } else {
s_settings->setValue(kTerminalCommandKey, term.command); s_settings->setValue(kTerminalCommandKey, term.command.toSettings());
s_settings->setValue(kTerminalOpenOptionsKey, term.openArgs); s_settings->setValue(kTerminalOpenOptionsKey, term.openArgs);
s_settings->setValue(kTerminalExecuteOptionsKey, term.executeArgs); s_settings->setValue(kTerminalExecuteOptionsKey, term.executeArgs);
} }

View File

@@ -5,6 +5,8 @@
#include "utils_global.h" #include "utils_global.h"
#include "filepath.h"
#include <QMetaType> #include <QMetaType>
#include <QVector> #include <QVector>
@@ -20,13 +22,13 @@ class QTCREATOR_UTILS_EXPORT TerminalCommand
{ {
public: public:
TerminalCommand() = default; TerminalCommand() = default;
TerminalCommand(const QString &command, const QString &openArgs, TerminalCommand(const FilePath &command, const QString &openArgs,
const QString &executeArgs, bool needsQuotes = false); const QString &executeArgs, bool needsQuotes = false);
bool operator==(const TerminalCommand &other) const; bool operator==(const TerminalCommand &other) const;
bool operator<(const TerminalCommand &other) const; bool operator<(const TerminalCommand &other) const;
QString command; Utils::FilePath command;
QString openArgs; QString openArgs;
QString executeArgs; QString executeArgs;
bool needsQuotes = false; bool needsQuotes = false;

View File

@@ -392,7 +392,7 @@ void TerminalImpl::start()
allArgs = QStringList { ProcessArgs::joinArgs(allArgs) }; allArgs = QStringList { ProcessArgs::joinArgs(allArgs) };
d->m_process.setEnvironment(m_setup.m_environment); d->m_process.setEnvironment(m_setup.m_environment);
d->m_process.setCommand({FilePath::fromString(terminal.command), allArgs}); d->m_process.setCommand({terminal.command, allArgs});
d->m_process.setProcessImpl(m_setup.m_processImpl); d->m_process.setProcessImpl(m_setup.m_processImpl);
d->m_process.setReaperTimeout(m_setup.m_reaperTimeout); d->m_process.setReaperTimeout(m_setup.m_reaperTimeout);
@@ -400,7 +400,7 @@ void TerminalImpl::start()
if (!d->m_process.waitForStarted()) { if (!d->m_process.waitForStarted()) {
const QString msg = Tr::tr("Cannot start the terminal emulator \"%1\", change the " const QString msg = Tr::tr("Cannot start the terminal emulator \"%1\", change the "
"setting in the Environment preferences. (%2)") "setting in the Environment preferences. (%2)")
.arg(terminal.command, d->m_process.errorString()); .arg(terminal.command.toUserOutput(), d->m_process.errorString());
cleanupAfterStartFailure(msg); cleanupAfterStartFailure(msg);
return; return;
} }

View File

@@ -197,7 +197,7 @@ public:
const QVector<TerminalCommand> availableTerminals const QVector<TerminalCommand> availableTerminals
= TerminalCommand::availableTerminalEmulators(); = TerminalCommand::availableTerminalEmulators();
for (const TerminalCommand &term : availableTerminals) for (const TerminalCommand &term : availableTerminals)
m_terminalComboBox->addItem(term.command, QVariant::fromValue(term)); m_terminalComboBox->addItem(term.command.toUserOutput(), QVariant::fromValue(term));
updateTerminalUi(TerminalCommand::terminalEmulator()); updateTerminalUi(TerminalCommand::terminalEmulator());
connect(m_terminalComboBox, &QComboBox::currentIndexChanged, this, [this](int index) { connect(m_terminalComboBox, &QComboBox::currentIndexChanged, this, [this](int index) {
updateTerminalUi(m_terminalComboBox->itemData(index).value<TerminalCommand>()); updateTerminalUi(m_terminalComboBox->itemData(index).value<TerminalCommand>());
@@ -373,9 +373,11 @@ void SystemSettingsWidget::apply()
QtcSettings *settings = ICore::settings(); QtcSettings *settings = ICore::settings();
EditorManager::setReloadSetting(IDocument::ReloadSetting(m_reloadBehavior->currentIndex())); EditorManager::setReloadSetting(IDocument::ReloadSetting(m_reloadBehavior->currentIndex()));
if (HostOsInfo::isAnyUnixHost()) { if (HostOsInfo::isAnyUnixHost()) {
TerminalCommand::setTerminalEmulator({m_terminalComboBox->lineEdit()->text(), TerminalCommand::setTerminalEmulator({
m_terminalOpenArgs->text(), FilePath::fromUserInput(m_terminalComboBox->lineEdit()->text()),
m_terminalExecuteArgs->text()}); m_terminalOpenArgs->text(),
m_terminalExecuteArgs->text()
});
if (!HostOsInfo::isMacHost()) { if (!HostOsInfo::isMacHost()) {
UnixUtils::setFileBrowser(settings, m_externalFileBrowserEdit->text()); UnixUtils::setFileBrowser(settings, m_externalFileBrowserEdit->text());
} }
@@ -423,7 +425,7 @@ void SystemSettingsWidget::resetTerminal()
void SystemSettingsWidget::updateTerminalUi(const TerminalCommand &term) void SystemSettingsWidget::updateTerminalUi(const TerminalCommand &term)
{ {
m_terminalComboBox->lineEdit()->setText(term.command); m_terminalComboBox->lineEdit()->setText(term.command.toUserOutput());
m_terminalOpenArgs->setText(term.openArgs); m_terminalOpenArgs->setText(term.openArgs);
m_terminalExecuteArgs->setText(term.executeArgs); m_terminalExecuteArgs->setText(term.executeArgs);
} }

View File

@@ -77,7 +77,7 @@ static void startTerminalEmulator(const QString &workingDir, const Environment &
#else #else
const TerminalCommand term = TerminalCommand::terminalEmulator(); const TerminalCommand term = TerminalCommand::terminalEmulator();
QProcess process; QProcess process;
process.setProgram(term.command); process.setProgram(term.command.nativePath());
process.setArguments(ProcessArgs::splitArgs(term.openArgs)); process.setArguments(ProcessArgs::splitArgs(term.openArgs));
process.setProcessEnvironment(env.toProcessEnvironment()); process.setProcessEnvironment(env.toProcessEnvironment());
process.setWorkingDirectory(workingDir); process.setWorkingDirectory(workingDir);