summaryrefslogtreecommitdiffstats
path: root/examples/assistant/remotecontrol/remotecontrol.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'examples/assistant/remotecontrol/remotecontrol.cpp')
-rw-r--r--examples/assistant/remotecontrol/remotecontrol.cpp186
1 files changed, 58 insertions, 128 deletions
diff --git a/examples/assistant/remotecontrol/remotecontrol.cpp b/examples/assistant/remotecontrol/remotecontrol.cpp
index 916a08efd..b4d1fe085 100644
--- a/examples/assistant/remotecontrol/remotecontrol.cpp
+++ b/examples/assistant/remotecontrol/remotecontrol.cpp
@@ -1,52 +1,5 @@
-/****************************************************************************
-**
-** Copyright (C) 2017 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of the examples of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:BSD$
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** BSD License Usage
-** Alternatively, you may use this file under the terms of the BSD license
-** as follows:
-**
-** "Redistribution and use in source and binary forms, with or without
-** modification, are permitted provided that the following conditions are
-** met:
-** * Redistributions of source code must retain the above copyright
-** notice, this list of conditions and the following disclaimer.
-** * Redistributions in binary form must reproduce the above copyright
-** notice, this list of conditions and the following disclaimer in
-** the documentation and/or other materials provided with the
-** distribution.
-** * Neither the name of The Qt Company Ltd nor the names of its
-** contributors may be used to endorse or promote products derived
-** from this software without specific prior written permission.
-**
-**
-** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
+// Copyright (C) 2017 The Qt Company Ltd.
+// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
#include "remotecontrol.h"
@@ -54,30 +7,48 @@
#include <QLibraryInfo>
#include <QMessageBox>
#include <QProcess>
-#include <QTextStream>
-RemoteControl::RemoteControl(QWidget *parent, Qt::WindowFlags flags)
- : QMainWindow(parent, flags)
+using namespace Qt::StringLiterals;
+
+RemoteControl::RemoteControl()
{
ui.setupUi(this);
- connect(ui.indexLineEdit, SIGNAL(returnPressed()),
- this, SLOT(on_indexButton_clicked()));
- connect(ui.identifierLineEdit, SIGNAL(returnPressed()),
- this, SLOT(on_identifierButton_clicked()));
- connect(ui.urlLineEdit, SIGNAL(returnPressed()),
- this, SLOT(on_urlButton_clicked()));
+ connect(ui.launchButton, &QPushButton::clicked, this, &RemoteControl::onLaunchClicked);
+
+ connect(ui.indexButton, &QPushButton::clicked, this, &RemoteControl::onIndexClicked);
+ connect(ui.indexLineEdit, &QLineEdit::returnPressed, this, &RemoteControl::onIndexClicked);
+
+ connect(ui.idButton, &QPushButton::clicked, this, &RemoteControl::onIdClicked);
+ connect(ui.idLineEdit, &QLineEdit::returnPressed, this, &RemoteControl::onIdClicked);
+
+ connect(ui.urlButton, &QPushButton::clicked, this, &RemoteControl::onUrlClicked);
+ connect(ui.urlLineEdit, &QLineEdit::returnPressed, this, &RemoteControl::onUrlClicked);
+
+ connect(ui.syncContentsButton, &QPushButton::clicked, this,
+ [this] { sendCommand("SyncContents"_L1); });
- QString rc;
- QTextStream(&rc) << QLatin1String("qthelp://org.qt-project.qtdoc.")
- << (QT_VERSION >> 16) << ((QT_VERSION >> 8) & 0xFF)
- << (QT_VERSION & 0xFF)
- << QLatin1String("/qtdoc/index.html");
+ connect(ui.contentsCheckBox, &QCheckBox::toggled, this, [this](bool checked) {
+ sendCommand(checked ? "Show Contents"_L1 : "Hide Contents"_L1);
+ });
+ connect(ui.indexCheckBox, &QCheckBox::toggled, this,
+ [this](bool checked) { sendCommand(checked ? "Show Index"_L1 : "Hide Index"_L1); });
+ connect(ui.bookmarksCheckBox, &QCheckBox::toggled, this, [this](bool checked) {
+ sendCommand(checked ? "Show Bookmarks"_L1 : "Hide Bookmarks"_L1);
+ });
- ui.startUrlLineEdit->setText(rc);
+ connect(ui.actionQuit, &QAction::triggered, this, &QMainWindow::close);
+
+ const QString versionString = QString::number(QT_VERSION_MAJOR)
+ + QString::number(QT_VERSION_MINOR) + QString::number(QT_VERSION_PATCH);
+ ui.startUrlLineEdit->setText("qthelp://org.qt-project.qtdoc."_L1 + versionString
+ + "/qdoc/qdoc-index.html"_L1);
process = new QProcess(this);
- connect(process, SIGNAL(finished(int,QProcess::ExitStatus)),
- this, SLOT(helpViewerClosed()));
+ connect(process, &QProcess::finished, this, [this] {
+ ui.launchButton->setEnabled(true);
+ ui.startUrlLineEdit->setEnabled(true);
+ ui.actionGroupBox->setEnabled(false);
+ });
}
RemoteControl::~RemoteControl()
@@ -88,96 +59,55 @@ RemoteControl::~RemoteControl()
}
}
-void RemoteControl::on_actionQuit_triggered()
-{
- close();
-}
-
-void RemoteControl::on_launchButton_clicked()
+void RemoteControl::onLaunchClicked()
{
if (process->state() == QProcess::Running)
return;
- QString app = QLibraryInfo::location(QLibraryInfo::BinariesPath) + QDir::separator();
+ QString app = QLibraryInfo::path(QLibraryInfo::BinariesPath);
#if !defined(Q_OS_MAC)
- app += QLatin1String("assistant");
+ app += "/assistant"_L1;
#else
- app += QLatin1String("Assistant.app/Contents/MacOS/Assistant");
+ app += "/Assistant.app/Contents/MacOS/Assistant"_L1;
#endif
- ui.contentsCheckBox->setChecked(true);
- ui.indexCheckBox->setChecked(true);
- ui.bookmarksCheckBox->setChecked(true);
-
- QStringList args;
- args << QLatin1String("-enableRemoteControl");
- process->start(app, args);
+ process->start(app, {"-enableRemoteControl"_L1});
if (!process->waitForStarted()) {
QMessageBox::critical(this, tr("Remote Control"),
- tr("Could not start Qt Assistant from %1.").arg(app));
+ tr("Could not start Qt Assistant from %1.").arg(QDir::toNativeSeparators(app)));
return;
}
+ ui.contentsCheckBox->setChecked(true);
+ ui.indexCheckBox->setChecked(true);
+ ui.bookmarksCheckBox->setChecked(true);
+
if (!ui.startUrlLineEdit->text().isEmpty())
- sendCommand(QLatin1String("SetSource ")
- + ui.startUrlLineEdit->text());
+ sendCommand("SetSource "_L1 + ui.startUrlLineEdit->text());
ui.launchButton->setEnabled(false);
ui.startUrlLineEdit->setEnabled(false);
ui.actionGroupBox->setEnabled(true);
}
-void RemoteControl::sendCommand(const QString &cmd)
-{
- if (process->state() != QProcess::Running)
- return;
- process->write(cmd.toLocal8Bit() + '\n');
-}
-
-void RemoteControl::on_indexButton_clicked()
-{
- sendCommand(QLatin1String("ActivateKeyword ")
- + ui.indexLineEdit->text());
-}
-
-void RemoteControl::on_identifierButton_clicked()
-{
- sendCommand(QLatin1String("ActivateIdentifier ")
- + ui.identifierLineEdit->text());
-}
-
-void RemoteControl::on_urlButton_clicked()
+void RemoteControl::onIndexClicked()
{
- sendCommand(QLatin1String("SetSource ")
- + ui.urlLineEdit->text());
+ sendCommand("ActivateKeyword "_L1 + ui.indexLineEdit->text());
}
-void RemoteControl::on_syncContentsButton_clicked()
+void RemoteControl::onIdClicked()
{
- sendCommand(QLatin1String("SyncContents"));
+ sendCommand("ActivateIdentifier "_L1 + ui.idLineEdit->text());
}
-void RemoteControl::on_contentsCheckBox_toggled(bool checked)
+void RemoteControl::onUrlClicked()
{
- sendCommand(checked ?
- QLatin1String("Show Contents") : QLatin1String("Hide Contents"));
+ sendCommand("SetSource "_L1 + ui.urlLineEdit->text());
}
-void RemoteControl::on_indexCheckBox_toggled(bool checked)
-{
- sendCommand(checked ?
- QLatin1String("Show Index") : QLatin1String("Hide Index"));
-}
-
-void RemoteControl::on_bookmarksCheckBox_toggled(bool checked)
-{
- sendCommand(checked ?
- QLatin1String("Show Bookmarks") : QLatin1String("Hide Bookmarks"));
-}
-
-void RemoteControl::helpViewerClosed()
+void RemoteControl::sendCommand(const QString &cmd)
{
- ui.launchButton->setEnabled(true);
- ui.startUrlLineEdit->setEnabled(true);
- ui.actionGroupBox->setEnabled(false);
+ if (process->state() != QProcess::Running)
+ return;
+ process->write(cmd.toLocal8Bit() + '\n');
}