2023-09-28 10:11:47 +02:00
|
|
|
#include <QGuiApplication>
|
|
|
|
#include <QQmlApplicationEngine>
|
|
|
|
|
|
|
|
#include <QDir>
|
|
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
QGuiApplication app(argc, argv);
|
2024-05-20 12:23:56 +03:00
|
|
|
QGuiApplication::setOrganizationName(QStringLiteral("Status"));
|
|
|
|
QGuiApplication::setOrganizationDomain(QStringLiteral("status.im"));
|
2023-09-28 10:11:47 +02:00
|
|
|
|
2024-03-08 17:20:20 +01:00
|
|
|
const QString pagesPath = QML_IMPORT_ROOT + QStringLiteral("/pages");
|
2023-09-28 10:11:47 +02:00
|
|
|
QDir pagesDir(pagesPath);
|
2024-03-08 17:20:20 +01:00
|
|
|
const QFileInfoList files = pagesDir.entryInfoList({QStringLiteral("*Page.qml")},
|
|
|
|
QDir::Files,
|
|
|
|
QDir::Name);
|
|
|
|
|
|
|
|
const QStringList additionalImportPaths{STATUSQ_MODULE_IMPORT_PATH,
|
|
|
|
QML_IMPORT_ROOT + QStringLiteral("/../ui/app"),
|
|
|
|
QML_IMPORT_ROOT + QStringLiteral("/../ui/imports"),
|
|
|
|
QML_IMPORT_ROOT + QStringLiteral("/src"),
|
|
|
|
QML_IMPORT_ROOT + QStringLiteral("/stubs")};
|
|
|
|
|
|
|
|
int errorCount = 0;
|
2024-05-20 12:23:56 +03:00
|
|
|
QStringList warnings;
|
|
|
|
QStringList failedPages;
|
|
|
|
|
2024-03-08 17:20:20 +01:00
|
|
|
for (const auto &fileInfo : files) {
|
2024-05-20 12:23:56 +03:00
|
|
|
warnings.clear();
|
2024-03-08 17:20:20 +01:00
|
|
|
QQmlApplicationEngine engine;
|
|
|
|
engine.setOutputWarningsToStandardError(false);
|
|
|
|
engine.setBaseUrl(QUrl::fromLocalFile(pagesPath + QDir::separator()));
|
|
|
|
|
|
|
|
for (const auto &path : additionalImportPaths)
|
|
|
|
engine.addImportPath(path);
|
|
|
|
|
2024-05-20 12:23:56 +03:00
|
|
|
QObject::connect(&engine, &QQmlApplicationEngine::warnings, &app, [&warnings](const QList<QQmlError> &qmlWarnings) {
|
|
|
|
for (const auto &qmlWarning: qmlWarnings)
|
|
|
|
warnings.append(qmlWarning.toString());
|
|
|
|
});
|
|
|
|
|
2024-03-08 17:20:20 +01:00
|
|
|
QObject::connect(&engine, &QQmlApplicationEngine::objectCreated,
|
2024-05-20 12:23:56 +03:00
|
|
|
&app, [&errorCount, &warnings, &failedPages](QObject *obj, const QUrl &objUrl) {
|
2024-03-08 17:20:20 +01:00
|
|
|
if (!obj) {
|
|
|
|
errorCount++;
|
2024-05-20 12:23:56 +03:00
|
|
|
failedPages << objUrl.toLocalFile();
|
|
|
|
|
|
|
|
for (const auto &warning: qAsConst(warnings))
|
|
|
|
qWarning() << " " << warning;
|
2024-03-08 17:20:20 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
auto fileName = fileInfo.filePath();
|
|
|
|
qInfo() << ">>> Checking StoryBook page:" << fileName;
|
|
|
|
|
|
|
|
engine.load(fileName);
|
2023-09-28 10:11:47 +02:00
|
|
|
}
|
|
|
|
|
2024-03-08 17:20:20 +01:00
|
|
|
if (errorCount) {
|
|
|
|
qWarning() << ">>> StoryBook page verification failed with" << errorCount << "errors.";
|
2024-05-20 12:23:56 +03:00
|
|
|
qWarning() << ">>> StoryBook pages with errors:" << failedPages;
|
|
|
|
|
2023-09-28 10:11:47 +02:00
|
|
|
return EXIT_FAILURE;
|
2024-03-08 17:20:20 +01:00
|
|
|
}
|
2023-09-28 10:11:47 +02:00
|
|
|
|
2024-03-08 17:20:20 +01:00
|
|
|
qInfo() << ">>> StoryBook page verification completed successfully.";
|
2023-09-28 10:11:47 +02:00
|
|
|
return EXIT_SUCCESS;
|
|
|
|
}
|