320779ccbe
The TODO said it was unused: it **is** used, but only in a very limited scope. Drop it from jobs where it wasn't useful (e.g. those that just return prettyName(), outside of the partition module).
150 lines
4.6 KiB
C++
150 lines
4.6 KiB
C++
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
|
*
|
|
* SPDX-FileCopyrightText: 2014-2015 Teo Mrnjavac <teo@kde.org>
|
|
* SPDX-FileCopyrightText: 2017 Adriaan de Groot <groot@kde.org>
|
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
|
*
|
|
* Calamares is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Calamares 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 General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with Calamares. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
#ifndef CALAMARES_JOB_H
|
|
#define CALAMARES_JOB_H
|
|
|
|
#include "DllMacro.h"
|
|
|
|
#include <QList>
|
|
#include <QObject>
|
|
#include <QSharedPointer>
|
|
|
|
namespace Calamares
|
|
{
|
|
|
|
class DLLEXPORT JobResult
|
|
{
|
|
public:
|
|
/** @brief Distinguish classes of errors
|
|
*
|
|
* All "ok result" have errorCode 0 (NoError).
|
|
* Errors returned from job execution have values < 0.
|
|
* Errors before job execution, or not returned by the job execution
|
|
* itself, have values > 0.
|
|
*/
|
|
enum
|
|
{
|
|
NoError = 0,
|
|
GenericError = -1,
|
|
PythonUncaughtException = 1,
|
|
InvalidConfiguration = 2
|
|
};
|
|
|
|
// Can't copy, but you can keep a temporary
|
|
JobResult( const JobResult& rhs ) = delete;
|
|
JobResult( JobResult&& rhs );
|
|
|
|
virtual ~JobResult() {}
|
|
|
|
/** @brief Is this JobResult a success?
|
|
*
|
|
* Equivalent to errorCode() == 0, might be named isValid().
|
|
*/
|
|
virtual operator bool() const;
|
|
|
|
virtual QString message() const;
|
|
virtual void setMessage( const QString& message );
|
|
|
|
virtual QString details() const;
|
|
virtual void setDetails( const QString& details );
|
|
|
|
int errorCode() const { return m_number; }
|
|
|
|
/// @brief an "ok status" result
|
|
static JobResult ok();
|
|
/** @brief an "error" result resulting from the execution of the job
|
|
*
|
|
* The error code is set to GenericError.
|
|
*/
|
|
static JobResult error( const QString& message, const QString& details = QString() );
|
|
/** @brief an "internal error" meaning the job itself has a problem (usually for python)
|
|
*
|
|
* Pass in a suitable error code; using 0 (which would normally mean "ok") instead
|
|
* gives you a GenericError code.
|
|
*/
|
|
static JobResult internalError( const QString&, const QString& details, int errorCode );
|
|
|
|
protected:
|
|
explicit JobResult( const QString& message, const QString& details, int errorCode );
|
|
|
|
private:
|
|
QString m_message;
|
|
QString m_details;
|
|
int m_number;
|
|
};
|
|
|
|
class DLLEXPORT Job : public QObject
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
explicit Job( QObject* parent = nullptr );
|
|
virtual ~Job();
|
|
|
|
/** @brief The job's (relative) weight.
|
|
*
|
|
* The default implementation returns 1.0, which gives all jobs
|
|
* the same weight, so they advance the overall progress the same
|
|
* amount. This is nonsense, since some jobs take much longer than
|
|
* others; it's up to the individual jobs to say something about
|
|
* how much work is (relatively) done.
|
|
*/
|
|
virtual qreal getJobWeight() const;
|
|
/** @brief The human-readable name of this job
|
|
*
|
|
* This should be a very short statement of what the job does.
|
|
* For status and state information, see prettyStatusMessage().
|
|
*/
|
|
virtual QString prettyName() const = 0;
|
|
/** @brief a longer human-readable description of what the job will do
|
|
*
|
|
* This **may** be used by view steps to fill in the summary
|
|
* messages for the summary page; at present, only the *partition*
|
|
* module does so.
|
|
*
|
|
* The default implementation returns an empty string.
|
|
*/
|
|
virtual QString prettyDescription() const;
|
|
/** @brief A human-readable status for progress reporting
|
|
*
|
|
* This is called from the JobQueue when progress is made, and should
|
|
* return a not-too-long description of the job's status. This
|
|
* is made visible in the progress bar of the execution view step.
|
|
*/
|
|
virtual QString prettyStatusMessage() const;
|
|
virtual JobResult exec() = 0;
|
|
|
|
bool isEmergency() const { return m_emergency; }
|
|
void setEmergency( bool e ) { m_emergency = e; }
|
|
|
|
signals:
|
|
void progress( qreal percent );
|
|
|
|
private:
|
|
bool m_emergency = false;
|
|
};
|
|
|
|
using job_ptr = QSharedPointer< Job >;
|
|
using JobList = QList< job_ptr >;
|
|
|
|
} // namespace Calamares
|
|
|
|
#endif // CALAMARES_JOB_H
|