X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=renderer%2Fkdenlive_render.cpp;h=079420b120b42f37aabea8f59f1ed2a8c2324859;hb=281a717b89dd5bfc6f3428b1d01195a103e98d63;hp=66d251742f509fb869f3ae751025430fc08ae190;hpb=e307ce736b87de6c928dfcc19d198fc6324dc9f0;p=kdenlive diff --git a/renderer/kdenlive_render.cpp b/renderer/kdenlive_render.cpp index 66d25174..079420b1 100644 --- a/renderer/kdenlive_render.cpp +++ b/renderer/kdenlive_render.cpp @@ -21,71 +21,120 @@ #include #include #include -#include - +#include +#include #include "renderjob.h" -int main(int argc, char **argv) { +int main(int argc, char **argv) +{ QCoreApplication app(argc, argv); QStringList args = app.arguments(); QStringList preargs; + QString locale; + int pid = 0; int in = -1; int out = -1; - if (!args.isEmpty()) args.takeFirst(); - if (args.count() >= 4) { + if (args.count() >= 7) { + // Remove program name + args.removeFirst(); + bool erase = false; if (args.at(0) == "-erase") { erase = true; - args.takeFirst(); + args.removeFirst(); } bool usekuiserver = false; if (args.at(0) == "-kuiserver") { usekuiserver = true; - args.takeFirst(); + args.removeFirst(); + } + if (QString(args.at(0)).startsWith("-pid:")) { + pid = QString(args.at(0)).section(':', 1).toInt(); + args.removeFirst(); } - if (args.at(0).startsWith("in=")) { - in = args.at(0).section('=', -1).toInt(); - args.takeFirst(); + + if (QString(args.at(0)).startsWith("-locale:")) { + locale = QString(args.at(0)).section(':', 1); + args.removeFirst(); } - if (args.at(0).startsWith("out=")) { - out = args.at(0).section('=', -1).toInt(); - args.takeFirst(); + if (args.at(0).startsWith("in=")) + in = args.takeFirst().section('=', -1).toInt(); + if (args.at(0).startsWith("out=")) + out = args.takeFirst().section('=', -1).toInt(); + if (args.at(0).startsWith("preargs=")) + preargs = args.takeFirst().section('=', 1).split(' ', QString::SkipEmptyParts); + + QString render = args.takeFirst(); + QString profile = args.takeFirst(); + QString rendermodule = args.takeFirst(); + QString player = args.takeFirst(); + QByteArray srcString = args.takeFirst().toUtf8(); + QUrl srcurl = QUrl::fromEncoded(srcString); + QString src = srcurl.path(); + // The QUrl path() strips the consumer: protocol, so re-add it if necessary + if (srcString.startsWith("consumer:")) + src.prepend("consumer:"); + QUrl desturl = QUrl::fromEncoded(args.takeFirst().toUtf8()); + QString dest = desturl.path(); + bool dualpass = false; + bool doerase; + QString vpre; + + int vprepos = args.indexOf(QRegExp("vpre=.*")); + if (vprepos >= 0) { + vpre=args.at(vprepos); } - if (args.at(0).startsWith("preargs=")) { - QString a = args.at(0).section('=', 1); - preargs = a.split(" ", QString::SkipEmptyParts); - args.takeFirst(); + QStringList vprelist = vpre.replace("vpre=", "").split(','); + if (vprelist.size() > 0) { + args.replaceInStrings(QRegExp("^vpre=.*"), QString("vpre=").append(vprelist.at(0))); } - QString render = args.at(0); - args.takeFirst(); - QString profile = args.at(0); - args.takeFirst(); - QString rendermodule = args.at(0); - args.takeFirst(); - QString player = args.at(0); - args.takeFirst(); - QString src = args.at(0); - args.takeFirst(); - QString dest = args.at(0); - args.takeFirst(); + + if (args.contains("pass=2")) { + // dual pass encoding + dualpass = true; + doerase = false; + args.replace(args.indexOf("pass=2"), "pass=1"); + if (args.contains("vcodec=libx264")) args << QString("passlogfile=%1").arg(dest + ".log"); + } else { + args.removeAll("pass=1"); + doerase = erase; + } + + // Decode metadata + for (int i = 0; i < args.count(); ++i) { + if (args.at(i).startsWith("meta.attr")) { + QString data = args.at(i); + args.replace(i, data.section('=', 0, 0) + "=\"" + QUrl::fromPercentEncoding(data.section('=', 1).toUtf8()) + "\""); + } + } + qDebug() << "//STARTING RENDERING: " << erase << "," << usekuiserver << "," << render << "," << profile << "," << rendermodule << "," << player << "," << src << "," << dest << "," << preargs << "," << args << "," << in << "," << out ; - RenderJob *job = new RenderJob(erase, usekuiserver, render, profile, rendermodule, player, src, dest, preargs, args, in, out); + RenderJob *job = new RenderJob(doerase, usekuiserver, pid, render, profile, rendermodule, player, src, dest, preargs, args, in, out); + if (!locale.isEmpty()) job->setLocale(locale); job->start(); + if (dualpass) { + if (vprelist.size()>1) + args.replaceInStrings(QRegExp("^vpre=.*"),QString("vpre=").append(vprelist.at(1))); + args.replace(args.indexOf("pass=1"), "pass=2"); + RenderJob *dualjob = new RenderJob(erase, usekuiserver, pid, render, profile, rendermodule, player, src, dest, preargs, args, in, out); + QObject::connect(job, SIGNAL(renderingFinished()), dualjob, SLOT(start())); + } app.exec(); } else { fprintf(stderr, "Kdenlive video renderer for MLT.\nUsage: " - "kdenlive_render [-erase] [-kuiserver] [in=pos] [out=pos] [render] [profile] [rendermodule] [player] [src] [dest] [[arg1] [arg2] ...]\n" + "kdenlive_render [-erase] [-kuiserver] [-locale:LOCALE] [in=pos] [out=pos] [render] [profile] [rendermodule] [player] [src] [dest] [[arg1] [arg2] ...]\n" " -erase: if that parameter is present, src file will be erased at the end\n" - " -kuiserver: if that parameter is present, use KDE job tracker\n" + " -kuiserver: if that parameter is present, use KDE job tracker\n" + " -locale:LOCALE : set a locale for rendering. For example, -locale:fr_FR.UTF-8 will use a french locale (comma as numeric separator)\n" " in=pos: start rendering at frame pos\n" " out=pos: end rendering at frame pos\n" - " render: path to inigo render\n" + " render: path to MLT melt renderer\n" " profile: the MLT video profile\n" " rendermodule: the MLT consumer used for rendering, usually it is avformat\n" " player: path to video player to play when rendering is over, use '-' to disable playing\n" - " src: source file (usually westley playlist)\n" - " dest: destination file\n" - " args: space separated libavformat arguments\n"); + " src: source file (usually MLT XML)\n" + " dest: destination file\n" + " args: space separated libavformat arguments\n"); } }