diff options
| author | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2016-01-21 06:34:51 +0000 |
|---|---|---|
| committer | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2016-01-21 06:34:51 +0000 |
| commit | 7f5637710f36ecfa818b06fe008d53d1cf234ba8 (patch) | |
| tree | 8ea340f6e3f68abc07bc1fc89a6115ff4237462a /src/plugins/General/converter/converterdialog.cpp | |
| parent | 58eacba4daf81e8b24201c81125c97ff55742869 (diff) | |
| download | qmmp-7f5637710f36ecfa818b06fe008d53d1cf234ba8.tar.gz qmmp-7f5637710f36ecfa818b06fe008d53d1cf234ba8.tar.bz2 qmmp-7f5637710f36ecfa818b06fe008d53d1cf234ba8.zip | |
converter: fixed some bugs
git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@6069 90c681e8-e032-0410-971d-27865f9a5e38
Diffstat (limited to 'src/plugins/General/converter/converterdialog.cpp')
| -rw-r--r-- | src/plugins/General/converter/converterdialog.cpp | 38 |
1 files changed, 36 insertions, 2 deletions
diff --git a/src/plugins/General/converter/converterdialog.cpp b/src/plugins/General/converter/converterdialog.cpp index 7bfafe37c..d4deea6df 100644 --- a/src/plugins/General/converter/converterdialog.cpp +++ b/src/plugins/General/converter/converterdialog.cpp @@ -25,6 +25,8 @@ #include <QDir> #include <QProgressBar> #include <QThreadPool> +#include <QProcess> +#include <QMessageBox> #include <qmmpui/playlistitem.h> #include <qmmpui/metadataformatter.h> #include <qmmpui/filedialog.h> @@ -109,6 +111,9 @@ void ConverterDialog::on_dirButton_clicked() void ConverterDialog::on_convertButton_clicked() { + if(!checkPreset(preset())) + return; + m_ui.convertButton->setEnabled(false); m_converters.clear(); for(int i = 0; i < m_ui.tableWidget->rowCount(); ++i) @@ -142,12 +147,16 @@ void ConverterDialog::on_stopButton_clicked() QThreadPool::globalInstance()->waitForDone(); qDeleteAll(m_converters); m_converters.clear(); + m_ui.convertButton->setEnabled(true); } void ConverterDialog::onConvertFinished(Converter *c) { - m_converters.removeAll(c); - delete c; + if(m_converters.contains(c)) + { + m_converters.removeAll(c); + delete c; + } if(m_converters.isEmpty()) m_ui.convertButton->setEnabled(true); } @@ -330,3 +339,28 @@ QString ConverterDialog::uniqueName(const QString &name) } return unique_name; } + +bool ConverterDialog::checkPreset(const QVariantMap &preset) +{ + QStringList programAndArgs = preset["command"].toString().split(" ", QString::SkipEmptyParts); + if(programAndArgs.isEmpty()) + return false; + + QString program = programAndArgs.first(); + + int result = QProcess::execute(program); + + if(result == -2) + { + QMessageBox::warning(this, tr("Error"), tr("Unable to execute \"%1\". Program not found.") + .arg(program)); + return false; + } + else if(result < 0) + { + QMessageBox::warning(this, tr("Error"), tr("Process \"%1\" finished with error.") + .arg(program)); + return false; + } + return true; +} |
