/* === This file is part of Calamares - === * * SPDX-FileCopyrightText: 2014-2015 Teo Mrnjavac * SPDX-FileCopyrightText: 2017 Adriaan de Groot * 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 . * */ #ifndef CALAMARES_JOB_H #define CALAMARES_JOB_H #include "DllMacro.h" #include #include #include 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