/* * * $Id: k3bjob.h 619556 2007-01-03 17:38:12Z trueg $ * Copyright (C) 2003 Sebastian Trueg <trueg@k3b.org> * * This file is part of the K3b project. * Copyright (C) 1998-2007 Sebastian Trueg <trueg@k3b.org> * * 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. * See the file "COPYING" for the exact licensing terms. */ #ifndef K3BJOB_H #define K3BJOB_H #include <tqobject.h> #include <tqptrlist.h> #include "k3bjobhandler.h" #include "k3b_export.h" class K3bDoc; namespace K3bDevice { class Device; } /** * This is the baseclass for all the jobs in K3b which actually do the work like burning a cd! * The K3bJob object takes care of registering with the k3bcore or with a parent K3bJob. * * Every job has a jobhandler which can be another job (in which case the job is handled as * a subjob) or an arbitrary class implementing the K3bJobHandler interface. * * A Job should never create any widgets. User interaction should be done through the methods * questionYesNo, waitForMedia. * * @author Sebastian Trueg */ class LIBK3B_EXPORT K3bJob : public TQObject, public K3bJobHandler { Q_OBJECT TQ_OBJECT public: virtual ~K3bJob(); /** * \reimplemented from K3bJobHandler */ bool isJob() const { return true; } K3bJobHandler* jobHandler() const { return m_jobHandler; } /** * Is the job active? * The default implementation is based on the jobStarted() and jobFinished() * methods and there is normally no need to reimplement this. */ virtual bool active() const { return m_active; } /** * The default implementation is based on the canceled() signal. * * This means that one cannot count on this value being valid * in a slot connected to the canceled() signal. It is, however, save * to call this method from a slot connected to the finished() signal * in case the job makes proper usage of the jobStarted/jobFinished * methods. */ virtual bool hasBeenCanceled() const { return m_canceled; } virtual TQString jobDescription() const { return "K3bJob"; } virtual TQString jobDetails() const { return TQString(); } /** * @returns the number of running subjobs. * this is useful for proper cancellation of jobs. */ unsigned int numRunningSubJobs() const; const TQPtrList<K3bJob>& runningSubJobs() const { return m_runningSubJobs; } /** * \deprecated */ virtual void connectSubJob( K3bJob* subJob, const char* finishedSlot = 0, bool progress = false, const char* progressSlot = 0, const char* subProgressSot = 0, const char* processedSizeSlot = 0, const char* processedSubSizeSlot = 0 ); static const char* DEFAULT_SIGNAL_CONNECTION; /** * \param newTaskSlot If DEFAULT_SIGNAL_CONNECTION the newTask signal from the subjob will * be connected to the newSubTask signal * \param newSubTaskSlot If DEFAULT_SIGNAL_CONNECTION the newSubTask signal from the subjob * will create an infoMessage signal * \param progressSlot If DEFAULT_SIGNAL_CONNECTION the percent signal of the subjob will be * connected to the subPercent signal. * debuggingOutput and infoMessage will always be direcctly connected. * * If a parameter is set to 0 it will not be connected at all */ virtual void connectSubJob( K3bJob* subJob, const char* finishedSlot = DEFAULT_SIGNAL_CONNECTION, const char* newTaskSlot = DEFAULT_SIGNAL_CONNECTION, const char* newSubTaskSlot = DEFAULT_SIGNAL_CONNECTION, const char* progressSlot = DEFAULT_SIGNAL_CONNECTION, const char* subProgressSlot = DEFAULT_SIGNAL_CONNECTION, const char* processedSizeSlot = DEFAULT_SIGNAL_CONNECTION, const char* processedSubSizeSlot = DEFAULT_SIGNAL_CONNECTION ); /** * Message types to be used in combination with the infoMessage signal. * * \see infoMessage() */ enum MessageType { INFO, /**< Informational message. For example a message that informs the user about what is currently going on */ WARNING, /**< A warning message. Something did not go perfectly but the job may continue. */ ERROR, /**< An error. Only use this message type if the job will actually fail afterwards with a call to jobFinished( false ) */ SUCCESS /**< This message type may be used to inform the user that a sub job has been successfully finished. */ }; /** * reimplemented from K3bJobHandler */ int waitForMedia( K3bDevice::Device*, int mediaState = K3bDevice::STATE_EMPTY, int mediaType = K3bDevice::MEDIA_WRITABLE_CD, const TQString& message = TQString() ); /** * reimplemented from K3bJobHandler */ bool questionYesNo( const TQString& text, const TQString& caption = TQString(), const TQString& yesText = TQString(), const TQString& noText = TQString() ); /** * reimplemented from K3bJobHandler */ void blockingInformation( const TQString& text, const TQString& caption = TQString() ); public slots: /** * This is the slot that starts the job. The first call should always * be jobStarted(). * * Once the job has finished it has to call jobFinished() with the result as * a parameter. * * \see jobStarted() * \see jobFinished() */ virtual void start() = 0; /** * This slot should cancel the job. The job has to emit the canceled() signal and make a call * to jobFinished(). * It is not important to do any of those two directly in this slot though. */ virtual void cancel() = 0; void setJobHandler( K3bJobHandler* ); signals: void infoMessage( const TQString& msg, int type ); void percent( int p ); void subPercent( int p ); void processedSize( int processed, int size ); void processedSubSize( int processed, int size ); void newTask( const TQString& job ); void newSubTask( const TQString& job ); void debuggingOutput(const TQString&, const TQString&); void data( const char* data, int len ); void nextTrack( int track, int numTracks ); void canceled(); /** * Emitted once the job has been started. Never emit this signal directly. * Use jobStarted() instead, otherwise the job will not be properly registered */ void started(); /** * Emitted once the job has been finshed. Never emit this signal directly. * Use jobFinished() instead, otherwise the job will not be properly deregistered */ void finished( bool success ); protected: /** * \param hdl the handler of the job. This allows for some user interaction without * specifying any details (like the GUI). * The job handler can also be another job. In that case this job is a sub job * and will be part of the parents running sub jobs. * * \see runningSubJobs() * \see numRunningSubJobs() */ K3bJob( K3bJobHandler* hdl, TQObject* parent = 0, const char* name = 0 ); /** * Call this in start() to properly register the job and emit the started() signal. * Do never emit the started() signal manually. * * Always call K3bJob::jobStarted in reimplementations. */ virtual void jobStarted(); /** * Call this at the end of the job to properly deregister the job and emit the finished() signal. * Do never emit the started() signal manually. * * Always call K3bJob::jobFinished in reimplementations. */ virtual void jobFinished( bool success ); private slots: void slotCanceled(); void slotNewSubTask( const TQString& str ); private: void registerSubJob( K3bJob* ); void unregisterSubJob( K3bJob* ); K3bJobHandler* m_jobHandler; TQPtrList<K3bJob> m_runningSubJobs; bool m_canceled; bool m_active; class Private; Private* d; }; /** * Every job used to actually burn a medium is derived from K3bBurnJob. * This class implements additional signals like buffer status or writing speed * as well as a handling of the used writing application. */ class LIBK3B_EXPORT K3bBurnJob : public K3bJob { Q_OBJECT TQ_OBJECT public: K3bBurnJob( K3bJobHandler* hdl, TQObject* parent = 0, const char* name = 0 ); virtual ~K3bBurnJob(); /** * The writing device used by this job. */ virtual K3bDevice::Device* writer() const { return 0; } /** * use K3b::WritingApp */ int writingApp() const { return m_writeMethod; } /** * K3b::WritingApp "ored" together */ virtual int supportedWritingApps() const; public slots: /** * use K3b::WritingApp */ void setWritingApp( int w ) { m_writeMethod = w; } signals: void bufferStatus( int ); void deviceBuffer( int ); /** * @param speed current writing speed in Kb * @param multiplicator use 150 for CDs and 1380 for DVDs * FIXME: maybe one should be able to ask the burnjob if it burns a CD or a DVD and remove the * multiplicator parameter) */ void writeSpeed( int speed, int multiplicator ); /** * This signal may be used to inform when the burning starts or ends * The BurningProgressDialog for example uses it to enable and disable * the buffer and writing speed displays. */ void burning(bool); private: int m_writeMethod; class Private; Private* d; }; #endif