forked from qt-creator/qt-creator
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:
@@ -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);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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({
|
||||||
|
FilePath::fromUserInput(m_terminalComboBox->lineEdit()->text()),
|
||||||
m_terminalOpenArgs->text(),
|
m_terminalOpenArgs->text(),
|
||||||
m_terminalExecuteArgs->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);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|||||||
Reference in New Issue
Block a user