/* Copyright (C) 2012 Carl Hetherington This program 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 2 of the License, or (at your option) any later version. This program 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 this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ /** @file src/job.h * @brief A parent class to represent long-running tasks which are run in their own thread. */ #ifndef DVDOMATIC_JOB_H #define DVDOMATIC_JOB_H #include #include #include class Log; class FilmState; class Options; /** @class Job * @brief A parent class to represent long-running tasks which are run in their own thread. */ class Job { public: Job (boost::shared_ptr s, boost::shared_ptr o, Log* l); /** @return user-readable name of this job */ virtual std::string name () const = 0; /** Run this job in the current thread. */ virtual void run () = 0; void start (); bool running () const; bool finished () const; bool finished_ok () const; bool finished_in_error () const; std::string error () const; int elapsed_time () const; virtual std::string status () const; void set_progress_unknown (); void set_progress (float); void ascend (); void descend (float); float overall_progress () const; void emit_finished (); /** Emitted from the GUI thread */ sigc::signal0 Finished; protected: enum State { NEW, ///< the job hasn't been started yet RUNNING, ///< the job is running FINISHED_OK, ///< the job has finished successfully FINISHED_ERROR ///< the job has finished in error }; void set_state (State); void set_error (std::string e); boost::shared_ptr _fs; boost::shared_ptr _opt; /** A log that this job can write to */ Log* _log; private: void run_wrapper (); /** mutex for _state and _error */ mutable boost::mutex _state_mutex; State _state; std::string _error; time_t _start_time; mutable boost::mutex _progress_mutex; struct Level { Level (float a) : allocation (a), normalised (0) {} float allocation; float normalised; }; std::list _stack; /** true if this job's progress will always be unknown */ bool _progress_unknown; }; #endif