X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=src%2Fmain.cpp;h=26768f0f64ce5f56bc381da84c4e72fdd36a65f9;hb=refs%2Fheads%2Fmaster;hp=3a0873f03a94e6eb7c2695a961db47e9b8e56cd2;hpb=533489a63a9716c645a11a99ca446978b20eedd0;p=minitube
diff --git a/src/main.cpp b/src/main.cpp
index 3a0873f..26768f0 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -18,14 +18,16 @@ along with Minitube. If not, see .
$END_LICENSE */
-#include
#include
+#include
-#include
#include "constants.h"
+#include "iconutils.h"
+#include "updateutils.h"
+
#include "mainwindow.h"
#include "searchparams.h"
-#include "iconutils.h"
+#include
#ifdef APP_EXTRA
#include "extra.h"
#endif
@@ -33,19 +35,20 @@ $END_LICENSE */
#include "mac_startup.h"
#endif
-void showWindow(QtSingleApplication &app, const QString &dataDir) {
+void showWindow(QtSingleApplication &app, const QString &pkgDataDir) {
MainWindow *mainWin = new MainWindow();
#ifndef APP_MAC
QIcon appIcon;
- if (QDir(dataDir).exists()) {
+ if (!pkgDataDir.isEmpty()) {
appIcon = IconUtils::icon(Constants::UNIX_NAME);
} else {
QString dataDir = qApp->applicationDirPath() + "/data";
- const int iconSizes [] = { 16, 22, 32, 48, 64, 128, 256, 512 };
+ const int iconSizes[] = {16, 22, 32, 48, 64, 128, 256, 512};
for (int i = 0; i < 8; i++) {
QString size = QString::number(iconSizes[i]);
- QString png = dataDir + "/" + size + "x" + size + "/" + Constants::UNIX_NAME + ".png";
+ QString png = dataDir + '/' + size + 'x' + size + '/' + Constants::UNIX_NAME +
+ QLatin1String(".png");
appIcon.addFile(png, QSize(iconSizes[i], iconSizes[i]));
}
}
@@ -53,33 +56,44 @@ void showWindow(QtSingleApplication &app, const QString &dataDir) {
mainWin->setWindowIcon(appIcon);
#endif
- mainWin->connect(&app, SIGNAL(messageReceived(const QString &)),
- mainWin, SLOT(messageReceived(const QString &)));
+ mainWin->connect(&app, SIGNAL(messageReceived(const QString &)), mainWin,
+ SLOT(messageReceived(const QString &)));
app.setActivationWindow(mainWin, true);
mainWin->show();
}
int main(int argc, char **argv) {
-#ifndef Q_NO_DEBUG_OUTPUT
+#ifndef QT_NO_DEBUG_OUTPUT
qSetMessagePattern("[%{function}] %{message}");
#endif
- // Seed random number generator
- qsrand(QDateTime::currentDateTime().toTime_t());
+#ifdef MEDIA_MPV
+ QSurfaceFormat format = QSurfaceFormat::defaultFormat();
+#ifdef APP_MAC
+ format.setMajorVersion(4);
+ format.setMinorVersion(1);
+#endif
+ format.setProfile(QSurfaceFormat::CoreProfile);
+ QSurfaceFormat::setDefaultFormat(format);
+#endif
#ifdef Q_OS_MAC
mac::MacMain();
#endif
+ QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
+
QtSingleApplication app(argc, argv);
- QString message = app.arguments().size() > 1 ? app.arguments().at(1) : QString();
- if (message == QLatin1String("--help")) {
- MainWindow::printHelp();
- return 0;
+ QString message;
+ if (app.arguments().size() > 1) {
+ message = app.arguments().at(1);
+ if (message == QLatin1String("--help")) {
+ MainWindow::printHelp();
+ return 0;
+ }
}
- if (app.sendMessage(message))
- return 0;
+ if (app.sendMessage(message)) return 0;
app.setApplicationName(Constants::NAME);
app.setOrganizationName(Constants::ORG_NAME);
@@ -96,6 +110,7 @@ int main(int argc, char **argv) {
cssFile.open(QFile::ReadOnly);
QString styleSheet = QLatin1String(cssFile.readAll());
app.setStyleSheet(styleSheet);
+ cssFile.close();
#endif
// qt translations
@@ -104,28 +119,32 @@ int main(int argc, char **argv) {
QLibraryInfo::location(QLibraryInfo::TranslationsPath));
app.installTranslator(&qtTranslator);
- // app translations
+ QString pkgDataDir;
#ifdef PKGDATADIR
- QString dataDir = QLatin1String(PKGDATADIR);
-#else
- QString dataDir = "";
+ pkgDataDir = QLatin1String(PKGDATADIR);
#endif
+
+ // app translations
#ifdef APP_MAC
QString localeDir = qApp->applicationDirPath() + QLatin1String("/../Resources/locale");
#else
QString localeDir = qApp->applicationDirPath() + QLatin1String("/locale");
#endif
if (!QDir(localeDir).exists()) {
- localeDir = dataDir + QLatin1String("/locale");
+ localeDir = pkgDataDir + QLatin1String("/locale");
}
- // qDebug() << "Using locale dir" << localeDir << locale;
+ qDebug() << "Using locale dir" << localeDir << QLocale::system();
QTranslator translator;
translator.load(QLocale::system(), QString(), QString(), localeDir);
app.installTranslator(&translator);
QNetworkProxyFactory::setUseSystemConfiguration(true);
- showWindow(app, dataDir);
+ IconUtils::setSizes({16, 24, 32, 88, 128});
+
+ UpdateUtils::init();
+
+ showWindow(app, pkgDataDir);
return app.exec();
}