X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=renderer%2Fkdenlive_render.cpp;h=593d002c367df9ce5968b01754ff0bdb0676a9ba;hb=4ae3260592acc87712db77b7d3fe0cc2be7d76bc;hp=ca352bdbc35997e3919611eb156f0f1657f3424d;hpb=c42a026234a44a2d766e57bc64a6ac7bbd094000;p=kdenlive diff --git a/renderer/kdenlive_render.cpp b/renderer/kdenlive_render.cpp index ca352bdb..593d002c 100644 --- a/renderer/kdenlive_render.cpp +++ b/renderer/kdenlive_render.cpp @@ -21,6 +21,7 @@ #include #include #include +#include #include #include "renderjob.h" @@ -30,76 +31,111 @@ 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(); - } - if (args.at(0).startsWith("in=")) { - in = args.at(0).section('=', -1).toInt(); - args.takeFirst(); + args.removeFirst(); } - if (args.at(0).startsWith("out=")) { - out = args.at(0).section('=', -1).toInt(); - args.takeFirst(); + if (QString(args.at(0)).startsWith("-pid:")) { + pid = QString(args.at(0)).section(':', 1).toInt(); + args.removeFirst(); } - if (args.at(0).startsWith("preargs=")) { - QString a = args.at(0).section('=', 1); - preargs = a.split(' ', QString::SkipEmptyParts); - args.takeFirst(); + + if (QString(args.at(0)).startsWith("-locale:")) { + locale = QString(args.at(0)).section(':', 1); + args.removeFirst(); } - 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.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); + } + QStringList vprelist = vpre.replace("vpre=", "").split(','); + if (vprelist.size() > 0) { + args.replaceInStrings(QRegExp("^vpre=.*"), QString("vpre=").append(vprelist.at(0))); + } + if (args.contains("pass=2")) { // dual pass encoding dualpass = true; doerase = false; args.replace(args.indexOf("pass=2"), "pass=1"); - } else doerase = erase; + 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(doerase, 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, render, profile, rendermodule, player, src, dest, preargs, args, in, out); + 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"); } }