/* * * $Id: k3bgrowisofshandler.h 619556 2007-01-03 17:38:12Z trueg $ * Copyright (C) 2003 Sebastian Trueg * * This file is part of the K3b project. * Copyright (C) 1998-2007 Sebastian Trueg * * 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 _K3B_GROWISOFS_HANDLER_H_ #define _K3B_GROWISOFS_HANDLER_H_ #include namespace K3bDevice { class Device; class DeviceHandler; } /** * This class handles the output parsing for growisofs * We put it in an extra class since we have two classes * using growisofs: the writer and the imager. */ class K3bGrowisofsHandler : public TQObject { Q_OBJECT TQ_OBJECT public: K3bGrowisofsHandler( TQObject* parent = 0, const char* name = 0 ); ~K3bGrowisofsHandler(); enum ErrorType { ERROR_UNKNOWN, ERROR_MEDIA, ERROR_OVERSIZE, ERROR_SPEED_SET_FAILED, ERROR_OPC, ERROR_MEMLOCK, ERROR_WRITE_FAILED }; int error() const { return m_error; } public slots: /** * This will basically reset the error type * @param dao was growisofs called with DAO? */ void reset( K3bDevice::Device* = 0, bool dao = false ); void handleStart(); void handleLine( const TQString& ); void handleExit( int exitCode ); signals: void infoMessage( const TQString&, int ); void newSubTask( const TQString& ); void buffer( int ); void deviceBuffer( int ); /** * We need this to know when the writing finished to update the progress */ void flushingCache(); private slots: void slotCheckBufferStatus(); void slotCheckBufferStatusDone( K3bDevice::DeviceHandler* ); private: class Private; Private* d; int m_error; bool m_dao; K3bDevice::Device* m_device; }; #endif