/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Copyright (C) 2019 Michael Zanetti * * * * This file is part of nymea. * * * * This library is free software; you can redistribute it and/or * * modify it under the terms of the GNU Lesser General Public * * License as published by the Free Software Foundation; either * * version 2.1 of the License, or (at your option) any later version. * * * * This library is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * * Lesser General Public License for more details. * * * * You should have received a copy of the GNU Lesser General Public * * License along with this library; If not, see * * . * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ #include "browseractioninfo.h" #include BrowserActionInfo::BrowserActionInfo(Device *device, const BrowserAction &browserAction, QObject *parent, quint32 timeout): QObject (parent), m_device(device), m_browserAction(browserAction) { connect(this, &BrowserActionInfo::finished, this, &BrowserActionInfo::deleteLater, Qt::QueuedConnection); if (timeout > 0) { QTimer::singleShot(timeout, this, [this] { emit aborted(); finish(Device::DeviceErrorTimeout); }); } } Device *BrowserActionInfo::device() const { return m_device; } BrowserAction BrowserActionInfo::browserAction() const { return m_browserAction; } bool BrowserActionInfo::isFinished() const { return m_finished; } Device::DeviceError BrowserActionInfo::status() const { return m_status; } void BrowserActionInfo::finish(Device::DeviceError status) { m_finished = true; m_status = status; staticMetaObject.invokeMethod(this, "finished", Qt::QueuedConnection); }