В Qt, как отменить QtConcurrentRun, если он не завершен к моменту выхода из приложения? - PullRequest
0 голосов
/ 19 февраля 2019

У меня есть приложение, которое выполняет предположительно долгую операцию на диске, которое я хочу запустить в фоновом режиме, как только приложение откроется.Однако, если задание не выполнено к моменту закрытия последнего окна, мне нужно отменить эту операцию.

Класс, выполняющий долгую работу в setRootPath:

class Scanner : public QObject
{
    Q_OBJECT
    Q_PROPERTY(QString currentPath READ currentPath NOTIFY currentPathChanged)
    Q_PROPERTY(bool done READ done NOTIFY doneChanged)
public:
    Scanner(QObject * parent = 0);
    QString currentPath() const;
    bool done() const;
    void setRootPath(QString root);
signals:
    void currentPathChanged(QString newPath);
    void doneChanged(bool newDone);
private:
    QString m_path;
    bool m_done;
};

Main:

int main(int argc, char *argv[])
{
    QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);

    QGuiApplication app(argc, argv);
    app.setQuitOnLastWindowClosed(false);

    Scanner scanner{};

    QQmlApplicationEngine engine;

    engine.rootContext()->setContextProperty("scanner", &scanner);
    QFuture<void> f = QtConcurrent::run(&scanner, &Scanner::setRootPath, QString("path/to/Pictures"));
    engine.load(QUrl(QStringLiteral("qrc:/main.qml")));
    if (engine.rootObjects().isEmpty())
        return -1;

    f.waitForFinished(); // of course, this hangs the gui... how do I get around that?
    return app.exec();
}

Я прочитал на форумах Qt , что мне нужно подключиться к сигналу lastWindowChanged, но я не могу понять, как использовать QObject :: connect здесь ... кто мой получатель

...