X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=src%2Fmain.cpp;h=26768f0f64ce5f56bc381da84c4e72fdd36a65f9;hb=refs%2Fheads%2Fmaster;hp=b462138da9382eaa86cb38336696e3d9af672b9a;hpb=7ca7741e1eb9bc70617fbb4207738e291218c495;p=minitube diff --git a/src/main.cpp b/src/main.cpp index b462138..26768f0 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -18,15 +18,16 @@ along with Minitube. If not, see . $END_LICENSE */ -#include -#if QT_VERSION >= 0x050000 +#include #include -#endif -#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 @@ -34,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])); } } @@ -54,28 +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 QT_NO_DEBUG_OUTPUT + qSetMessagePattern("[%{function}] %{message}"); +#endif + +#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(); - // QFont::insertSubstitution(".Helvetica Neue DeskInterface", "Helvetica Neue"); #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); @@ -92,43 +110,41 @@ int main(int argc, char **argv) { cssFile.open(QFile::ReadOnly); QString styleSheet = QLatin1String(cssFile.readAll()); app.setStyleSheet(styleSheet); + cssFile.close(); #endif // qt translations QTranslator qtTranslator; - qtTranslator.load("qt_" + QLocale::system().name(), + qtTranslator.load(QLatin1String("qt_") + QLocale::system().name(), 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() + "/../Resources/locale"; + QString localeDir = qApp->applicationDirPath() + QLatin1String("/../Resources/locale"); #else - QString localeDir = qApp->applicationDirPath() + "/locale"; + QString localeDir = qApp->applicationDirPath() + QLatin1String("/locale"); #endif if (!QDir(localeDir).exists()) { - localeDir = dataDir + "/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); -#if QT_VERSION < 0x050000 - QTextCodec::setCodecForTr(QTextCodec::codecForName("utf8")); -#endif - // Seed random number generator - qsrand(QDateTime::currentDateTime().toTime_t()); + QNetworkProxyFactory::setUseSystemConfiguration(true); + + IconUtils::setSizes({16, 24, 32, 88, 128}); - // all string literals are UTF-8 - // QTextCodec::setCodecForCStrings(QTextCodec::codecForName("UTF-8")); + UpdateUtils::init(); - showWindow(app, dataDir); + showWindow(app, pkgDataDir); return app.exec(); }