mirror of
https://gitlab.com/kelteseth/ScreenPlay.git
synced 2024-11-22 18:52:30 +01:00
73932d8999
... or the main app is still running
163 lines
6.4 KiB
C++
163 lines
6.4 KiB
C++
// SPDX-License-Identifier: LicenseRef-EliasSteurerTachiom OR AGPL-3.0-only
|
|
|
|
#include "ScreenPlayWidget/CMakeVariables.h"
|
|
#include <QGuiApplication>
|
|
#include <QQmlApplicationEngine>
|
|
#include <QQmlExtensionPlugin>
|
|
#include <QString>
|
|
#include <QStringList>
|
|
#include <QtWebEngineQuick>
|
|
|
|
#include "ScreenPlayUtil/contenttypes.h"
|
|
#include "ScreenPlayUtil/exitcodes.h"
|
|
#include "ScreenPlayUtil/logginghandler.h"
|
|
#include "src/widgetwindow.h"
|
|
|
|
#if defined(Q_OS_WIN)
|
|
Q_IMPORT_QML_PLUGIN(ScreenPlaySysInfoPlugin)
|
|
#endif
|
|
#if defined(Q_OS_MACOS)
|
|
#include "ScreenPlayUtil/macutils.h"
|
|
#endif
|
|
|
|
Q_IMPORT_QML_PLUGIN(ScreenPlayWeatherPlugin)
|
|
Q_IMPORT_QML_PLUGIN(ScreenPlayUtilPlugin)
|
|
|
|
int main(int argc, char* argv[])
|
|
{
|
|
|
|
using namespace ScreenPlay;
|
|
// Lets keep using it until: https://bugreports.qt.io/browse/QTBUG-109401
|
|
QtWebEngineQuick::initialize();
|
|
|
|
#if defined(Q_OS_WIN)
|
|
// Workaround for Qt 6.5.1 crash https://bugreports.qt.io/browse/QTBUG-113832
|
|
qputenv("QT_DISABLE_HW_TEXTURES_CONVERSION", "1");
|
|
qputenv("QT_MEDIA_BACKEND", "ffmpeg");
|
|
#endif
|
|
|
|
QGuiApplication app(argc, argv);
|
|
std::unique_ptr<const ScreenPlayUtil::LoggingHandler> logging;
|
|
|
|
QStringList argumentList;
|
|
|
|
// If we start with only one argument (path, appID, type),
|
|
// it means we want to test a single widget
|
|
if (app.arguments().length() == 1) {
|
|
QString exampleContentPath = QString(SCREENPLAY_SOURCE_DIR) + "/Content";
|
|
using namespace ScreenPlay;
|
|
QList<QPair<QString, ContentTypes::InstalledType>> contentFolder = {
|
|
{ "/widget_weather", ContentTypes::InstalledType::QMLWidget }, // 0
|
|
{ "/widget_system_stats", ContentTypes::InstalledType::QMLWidget }, // 1 (Note: Windows only)
|
|
{ "/widget_hello_world", ContentTypes::InstalledType::QMLWidget }, // 2
|
|
{ "/widget_year_count_down", ContentTypes::InstalledType::QMLWidget }, // 3
|
|
{ "/widget_analog_clock", ContentTypes::InstalledType::QMLWidget }, // 4
|
|
{ "/widget_digital_clock", ContentTypes::InstalledType::QMLWidget }, // 5
|
|
{ "/widget_rss_hackernews", ContentTypes::InstalledType::QMLWidget }, // 6
|
|
{ "/widget_rss_guardian_news", ContentTypes::InstalledType::QMLWidget }, // 7
|
|
{ "/widget_xkcd", ContentTypes::InstalledType::QMLWidget }, // 8
|
|
};
|
|
const int index = 5;
|
|
QString projectPath = exampleContentPath + contentFolder.at(index).first;
|
|
|
|
// Lets center the widget
|
|
const auto* screen = QGuiApplication::screens().at(0);
|
|
const int offset = -200;
|
|
const QPoint center((screen->size().width() / 2) + offset, (screen->size().height() / 2) + offset);
|
|
const QString type = QVariant::fromValue<ContentTypes::InstalledType>(contentFolder.at(index).second).toString();
|
|
|
|
argumentList.append(
|
|
QStringList {
|
|
// Docs: Don't forget that arguments must start with the name of the executable (ignored, though).
|
|
QGuiApplication::applicationName(),
|
|
"--projectpath", projectPath,
|
|
"--appID", "qmz9lq4wglox5DdYaXumVgRSDeZYAUjC",
|
|
"--type", type,
|
|
"--posX", QString::number(center.x()),
|
|
"--posY", QString::number(center.y()),
|
|
"--mainapppid", "1" });
|
|
} else {
|
|
argumentList = app.arguments();
|
|
}
|
|
|
|
QCommandLineParser parser;
|
|
parser.setApplicationDescription("ScreenPlay Widget");
|
|
parser.addHelpOption();
|
|
QCommandLineOption pathOption("projectpath", "Project path", "projectpath");
|
|
QCommandLineOption appIDOption("appID", "Application ID", "appid");
|
|
QCommandLineOption typeOption("type", "Content type", "type");
|
|
QCommandLineOption posXOption("posX", "X position", "positionX");
|
|
QCommandLineOption posYOption("posY", "Y position", "positionY");
|
|
QCommandLineOption mainAppPidOption("mainapppid", "pid of the main ScreenPlay app. User to check if we are still alive.", "mainapppid");
|
|
|
|
// Add the options to the parser
|
|
parser.addOption(pathOption);
|
|
parser.addOption(appIDOption);
|
|
parser.addOption(typeOption);
|
|
parser.addOption(posXOption);
|
|
parser.addOption(posYOption);
|
|
parser.addOption(mainAppPidOption);
|
|
|
|
// Process the actual command line arguments given by the user
|
|
parser.process(argumentList);
|
|
|
|
// Check if all required options are provided
|
|
if (!parser.isSet(pathOption)
|
|
|| !parser.isSet(appIDOption)
|
|
|| !parser.isSet(typeOption)
|
|
|| !parser.isSet(posXOption)
|
|
|| !parser.isSet(posYOption)
|
|
|| !parser.isSet(mainAppPidOption)) {
|
|
qCritical() << "Missing required arguments. Please provide all arguments."
|
|
<< argumentList
|
|
<< "pathOption" << parser.value(pathOption)
|
|
<< "appIDOption" << parser.value(appIDOption)
|
|
<< "typeOption" << parser.value(typeOption)
|
|
<< "posXOption" << parser.value(posXOption)
|
|
<< "posYOption" << parser.value(posYOption)
|
|
<< "mainAppPidOption" << parser.value(mainAppPidOption);
|
|
return static_cast<int>(WidgetExit::Code::Invalid_ArgumentSize);
|
|
}
|
|
|
|
QString pid = parser.value(mainAppPidOption);
|
|
QString appID = parser.value(appIDOption);
|
|
QString projectPath = parser.value(pathOption);
|
|
QString type = parser.value(typeOption);
|
|
|
|
bool okPosX = false, okPosY = false;
|
|
const int positionX = parser.value(posXOption).toInt(&okPosX);
|
|
if (!okPosX) {
|
|
qWarning() << "Could not parse PositionX value to int: " << parser.value(posXOption);
|
|
return static_cast<int>(WidgetExit::Code::Invalid_POSX);
|
|
}
|
|
|
|
const int positionY = parser.value(posYOption).toInt(&okPosY);
|
|
if (!okPosY) {
|
|
qWarning() << "Could not parse PositionY value to int: " << parser.value(posYOption);
|
|
return static_cast<int>(WidgetExit::Code::Invalid_POSY);
|
|
}
|
|
|
|
bool okPid = false;
|
|
const qint64 mainAppPidInt = pid.toInt(&okPid);
|
|
if (!okPid) {
|
|
qCritical("Could not parse mainAppPid");
|
|
return static_cast<int>(WidgetExit::Code::Invalid_PID);
|
|
}
|
|
|
|
WidgetWindow spwmw(
|
|
projectPath,
|
|
appID,
|
|
type,
|
|
QPoint { positionX, positionY },
|
|
mainAppPidInt,
|
|
false);
|
|
|
|
#if defined(Q_OS_MACOS)
|
|
MacUtils::showDockIcon(false);
|
|
#endif
|
|
logging = std::make_unique<const ScreenPlayUtil::LoggingHandler>("ScreenPlayWidget_" + appID);
|
|
const int status = app.exec();
|
|
logging.reset();
|
|
return status;
|
|
}
|