+void RenderWidget::slotCheckScript()
+{
+ QTreeWidgetItem *item = m_view.scripts_list->currentItem();
+ if (item == NULL) return;
+ m_view.start_script->setEnabled(item->data(0, Qt::UserRole).toString().isEmpty());
+ m_view.delete_script->setEnabled(true);
+}
+
+void RenderWidget::slotStartScript()
+{
+ QTreeWidgetItem *item = m_view.scripts_list->currentItem();
+ if (item) {
+ QString destination = item->data(1, Qt::UserRole).toString();
+ QString path = item->data(1, Qt::UserRole + 1).toString();
+ // Insert new job in queue
+ QTreeWidgetItem *renderItem;
+ QList<QTreeWidgetItem *> existing = m_view.running_jobs->findItems(destination, Qt::MatchExactly, 1);
+ kDebug() << "------ START SCRIPT";
+ if (!existing.isEmpty()) {
+ renderItem = existing.at(0);
+ if (renderItem->data(1, Qt::UserRole + 2).toInt() == RUNNINGJOB) {
+ KMessageBox::information(this, i18n("There is already a job writing file:<br /><b>%1</b><br />Abort the job if you want to overwrite it...", destination), i18n("Already running"));
+ return;
+ }
+ } else renderItem = new QTreeWidgetItem(m_view.running_jobs, QStringList() << QString() << destination << QString());
+ kDebug() << "------ START SCRIPT 2";
+ renderItem->setData(2, Qt::UserRole, 0);
+ renderItem->setData(1, Qt::UserRole + 2, WAITINGJOB);
+ renderItem->setIcon(0, KIcon("media-playback-pause"));
+ renderItem->setData(1, Qt::UserRole, i18n("Waiting..."));
+ renderItem->setSizeHint(1, QSize(m_view.running_jobs->columnWidth(1), fontMetrics().height() * 2));
+ renderItem->setData(1, Qt::UserRole + 1, QTime::currentTime());
+ renderItem->setData(1, Qt::UserRole + 3, path);
+ renderItem->setData(1, Qt::UserRole + 4, '1');
+ checkRenderStatus();
+ m_view.tabWidget->setCurrentIndex(1);
+ }
+}
+
+void RenderWidget::slotDeleteScript()
+{
+ QTreeWidgetItem *item = m_view.scripts_list->currentItem();
+ if (item) {
+ QString path = item->data(1, Qt::UserRole + 1).toString();
+ KIO::NetAccess::del(path + ".mlt", this);
+ KIO::NetAccess::del(path, this);
+ parseScriptFiles();
+ }
+}
+
+void RenderWidget::slotGenerateScript()
+{
+ slotPrepareExport(true);
+}
+
+void RenderWidget::slotHideLog()
+{
+ m_view.error_box->setVisible(false);
+}
+
+void RenderWidget::setRenderProfile(const QString &dest, const QString &group, const QString &name, const QString &url)
+{
+ m_view.destination_list->blockSignals(true);
+ m_view.format_list->blockSignals(true);
+
+ if (!url.isEmpty()) m_view.out_file->setUrl(KUrl(url));
+
+ // set destination
+ for (int i = 0; i < m_view.destination_list->count(); i++) {
+ if (m_view.destination_list->itemData(i, Qt::UserRole) == dest) {
+ m_view.destination_list->setCurrentIndex(i);
+ break;
+ }
+ }
+ refreshCategory();
+
+ // set category
+ if (!group.isEmpty()) {
+ QList<QListWidgetItem *> childs = m_view.format_list->findItems(group, Qt::MatchExactly);
+ if (!childs.isEmpty()) {
+ m_view.format_list->setCurrentItem(childs.at(0));
+ m_view.format_list->scrollToItem(childs.at(0));
+ }
+ refreshView();
+ }
+
+ // set profile
+ QList<QListWidgetItem *> childs = m_view.size_list->findItems(name, Qt::MatchExactly);
+ if (!childs.isEmpty()) {
+ m_view.size_list->setCurrentItem(childs.at(0));
+ m_view.size_list->scrollToItem(childs.at(0));
+ }
+ //refreshView();
+ m_view.destination_list->blockSignals(false);
+ m_view.format_list->blockSignals(false);
+
+}
+
+bool RenderWidget::startWaitingRenderJobs()
+{
+ m_blockProcessing = true;
+ QString autoscriptFile = getFreeScriptName("auto");
+ QFile file(autoscriptFile);
+ if (!file.open(QIODevice::WriteOnly | QIODevice::Text)) {
+ kWarning() << "////// ERROR writing to file: " << autoscriptFile;
+ KMessageBox::error(0, i18n("Cannot write to file %1", autoscriptFile));
+ return false;
+ }
+
+ QTextStream outStream(&file);
+ outStream << "#! /bin/sh" << "\n" << "\n";
+ QTreeWidgetItem *item = m_view.running_jobs->topLevelItem(0);
+ while (item) {
+ if (item->data(1, Qt::UserRole + 2).toInt() == WAITINGJOB) {
+ if (item->data(1, Qt::UserRole + 4).isNull()) {
+ // Add render process for item
+ const QString params = item->data(1, Qt::UserRole + 3).toStringList().join(" ");
+ outStream << m_renderer << " " << params << "\n";
+ } else {
+ // Script item
+ outStream << item->data(1, Qt::UserRole + 3).toString() << "\n";
+ }
+ }
+ item = m_view.running_jobs->itemBelow(item);
+ }
+ // erase itself when rendering is finished
+ outStream << "rm " << autoscriptFile << "\n" << "\n";
+ if (file.error() != QFile::NoError) {
+ KMessageBox::error(0, i18n("Cannot write to file %1", autoscriptFile));
+ file.close();
+ m_blockProcessing = false;
+ return false;
+ }
+ file.close();
+ QFile::setPermissions(autoscriptFile, file.permissions() | QFile::ExeUser);
+ QProcess::startDetached(autoscriptFile, QStringList());
+ return true;
+}
+
+QString RenderWidget::getFreeScriptName(const QString &prefix)
+{
+ int ix = 0;
+ QString scriptsFolder = m_projectFolder + "scripts/";
+ KStandardDirs::makeDir(scriptsFolder);
+ QString path;
+ while (path.isEmpty() || QFile::exists(path)) {
+ ix++;
+ path = scriptsFolder + prefix + i18n("script") + QString::number(ix).rightJustified(3, '0', false) + ".sh";
+ }
+ return path;
+}
+
+void RenderWidget::slotPlayRendering(QTreeWidgetItem *item, int)
+{
+ if (KdenliveSettings::defaultplayerapp().isEmpty() || item->data(1, Qt::UserRole + 2).toInt() != FINISHEDJOB) return;
+ const QByteArray startId = KStartupInfo::createNewStartupId();
+ const QString command = KdenliveSettings::defaultplayerapp() + ' ' + item->text(1);
+ KRun::runCommand(command, KdenliveSettings::defaultplayerapp(), KdenliveSettings::defaultplayerapp(), this, startId);
+}
+
+void RenderWidget::missingClips(bool hasMissing)
+{
+ if (hasMissing) {
+ m_view.errorLabel->setText(i18n("Check missing clips"));
+ m_view.errorLabel->setHidden(false);
+ } else m_view.errorLabel->setHidden(true);
+}
+
+void RenderWidget::enableAudio(bool enable)
+{
+ m_view.export_audio->setChecked(enable);
+}
+
+void RenderWidget::slotUpdateRescaleWidth(int val)
+{
+ KdenliveSettings::setDefaultrescalewidth(val);
+ if (!m_view.rescale_keep->isChecked()) return;
+ m_view.rescale_height->blockSignals(true);
+ m_view.rescale_height->setValue(val * m_profile.height / m_profile.width + 0.5);
+ KdenliveSettings::setDefaultrescaleheight(m_view.rescale_height->value());
+ m_view.rescale_height->blockSignals(false);
+}
+
+void RenderWidget::slotUpdateRescaleHeight(int val)
+{
+ KdenliveSettings::setDefaultrescaleheight(val);
+ if (!m_view.rescale_keep->isChecked()) return;
+ m_view.rescale_width->blockSignals(true);
+ m_view.rescale_width->setValue(val * m_profile.width / m_profile.height + 0.5);
+ KdenliveSettings::setDefaultrescaleheight(m_view.rescale_width->value());
+ m_view.rescale_width->blockSignals(false);
+}
+
+void RenderWidget::slotSwitchAspectRatio()
+{
+ KdenliveSettings::setRescalekeepratio(m_view.rescale_keep->isChecked());
+ if (m_view.rescale_keep->isChecked()) slotUpdateRescaleWidth(m_view.rescale_width->value());
+}