/////////////////////////////////////////////////////////////////////////////// // LameXP - Audio Encoder Front-End // Copyright (C) 2004-2011 LoRd_MuldeR // // 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., // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. // // http://www.gnu.org/licenses/gpl-2.0.txt /////////////////////////////////////////////////////////////////////////////// #pragma once #include #include #include class AudioFileModel; class CueSheetModel; class QFile; class QDir; class QFileInfo; //////////////////////////////////////////////////////////// // Splash Thread //////////////////////////////////////////////////////////// class CueSplitter: public QThread { Q_OBJECT public: CueSplitter(const QString &outputDir, const QString &baseName, CueSheetModel *model, const QList &inputFilesInfo); ~CueSplitter(void); void run(); unsigned int getTracksSuccess(void) { return m_nTracksSuccess; } unsigned int getTracksSkipped(void) { return m_nTracksSkipped; } bool getSuccess(void) { return !isRunning() && m_bSuccess; } bool getAborted(void) { return m_bAborted; } signals: void fileSelected(const QString &fileName); void fileSplit(const AudioFileModel &file); private slots: void handleUpdate(int progress); public slots: void abortProcess(void) { m_abortFlag = true; } private: void splitFile(const QString &output, const int trackNo, const QString &file, const double offset, const double length, const AudioFileModel &metaInfo, int &maxProgress); QString indexToString(const double index) const; QString shortName(const QString &longName) const; const QString m_soxBin; const QString m_outputDir; const QString m_baseName; unsigned int m_nTracksSuccess; unsigned int m_nTracksSkipped; static const int m_processTimeoutInterval = 180000; bool m_bAborted; bool m_bSuccess; volatile bool m_abortFlag; CueSheetModel *m_model; QMap m_inputFilesInfo; QMap m_decompressedFiles; QStringList m_tempFiles; QString m_activeFile; };