X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=app%2Fmain.cpp;h=c3e0fb0429108c4b380e1a0054440b1b38d8e324;hb=92e613114ff5212fa7e5c2a226e32b6e252c9a9c;hp=e8d4082f354b6db2c3a2c6b01c6933345b5eb148;hpb=4eee2655560fbb2f7724095bb7fa488f3f39ba55;p=apps%2Fmediaplayer.git diff --git a/app/main.cpp b/app/main.cpp index e8d4082..c3e0fb0 100644 --- a/app/main.cpp +++ b/app/main.cpp @@ -14,9 +14,11 @@ * limitations under the License. */ +#include #include #include #include +#include #include #include #include @@ -27,33 +29,6 @@ #include #endif -#ifdef HAVE_LIGHTMEDIASCANNER -#include "lightmediascanner.h" -#endif - -#ifdef HAVE_DBUS -#include "dbus.h" -#endif - -#include "playlistwithmetadata.h" - -#ifndef HAVE_LIGHTMEDIASCANNER -QVariantList readMusicFile(const QString &path) -{ - QVariantList ret; - QDir dir(path); - for (const auto &entry : dir.entryList(QDir::Dirs | QDir::Files | QDir::NoDotAndDotDot, QDir::Name)) { - QFileInfo fileInfo(dir.absoluteFilePath(entry)); - if (fileInfo.isDir()) { - ret.append(readMusicFile(fileInfo.absoluteFilePath())); - } else if (fileInfo.isFile()) { - ret.append(QUrl::fromLocalFile(fileInfo.absoluteFilePath())); - } - } - return ret; -} -#endif - int main(int argc, char *argv[]) { #ifdef HAVE_LIBHOMESCREEN @@ -69,30 +44,31 @@ int main(int argc, char *argv[]) QQuickStyle::setStyle("AGL"); - qmlRegisterType("MediaPlayer", 1, 0, "PlaylistWithMetadata"); - - QVariantList mediaFiles; - -#ifdef HAVE_LIGHTMEDIASCANNER - mediaFiles = LightMediaScanner::processLightMediaScanner(); -#else - QString music; - - for (const auto &music : QStandardPaths::standardLocations(QStandardPaths::MusicLocation)) { - mediaFiles.append(readMusicFile(music)); - } -#endif - QQmlApplicationEngine engine; QQmlContext *context = engine.rootContext(); - context->setContextProperty("mediaFiles", mediaFiles); -#if defined(HAVE_DBUS) && defined(HAVE_LIGHTMEDIASCANNER) - DbusService dbus_service; - context->setContextProperty("dbus", &dbus_service); - if (!dbus_service.enableLMS()) - qWarning() << "Cannot run enableLMS"; -#endif + QCommandLineParser parser; + parser.addPositionalArgument("port", app.translate("main", "port for binding")); + parser.addPositionalArgument("secret", app.translate("main", "secret for binding")); + parser.addHelpOption(); + parser.addVersionOption(); + parser.process(app); + QStringList positionalArguments = parser.positionalArguments(); + + if (positionalArguments.length() == 2) { + int port = positionalArguments.takeFirst().toInt(); + QString secret = positionalArguments.takeFirst(); + QUrl bindingAddress; + bindingAddress.setScheme(QStringLiteral("ws")); + bindingAddress.setHost(QStringLiteral("localhost")); + bindingAddress.setPort(port); + bindingAddress.setPath(QStringLiteral("/api")); + QUrlQuery query; + query.addQueryItem(QStringLiteral("token"), secret); + bindingAddress.setQuery(query); + context->setContextProperty(QStringLiteral("bindingAddress"), bindingAddress); + } + engine.load(QUrl(QStringLiteral("qrc:/MediaPlayer.qml"))); return app.exec();