1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
#include <QThread>
#include <QDir>
#include <QtDebug>
#include <QApplication>
#include <QStringList>
#include <QString>
#include <QTextCodec>
#include "mixxx.h"
#include "mixxxapplication.h"
#include "sources/soundsourceproxy.h"
#include "errordialoghandler.h"
#include "util/cmdlineargs.h"
#include "util/console.h"
#include "util/logging.h"
#include "util/version.h"
#ifdef Q_OS_LINUX
#include <X11/Xlib.h>
#endif
namespace {
// Exit codes
constexpr int kFatalErrorOnStartupExitCode = 1;
constexpr int kParseCmdlineArgsErrorExitCode = 2;
int runMixxx(MixxxApplication* app, const CmdlineArgs& args) {
MixxxMainWindow mainWindow(app, args);
// If startup produced a fatal error, then don't even start the
// Qt event loop.
if (ErrorDialogHandler::instance()->checkError()) {
mainWindow.finalize();
return kFatalErrorOnStartupExitCode;
} else {
qDebug() << "Displaying main window";
mainWindow.show();
qDebug() << "Running Mixxx";
return app->exec();
}
}
} // anonymous namespace
int main(int argc, char * argv[]) {
Console console;
#ifdef Q_OS_LINUX
XInitThreads();
#endif
// These need to be set early on (not sure how early) in order to trigger
// logic in the OS X appstore support patch from QTBUG-16549.
QCoreApplication::setOrganizationDomain("mixxx.org");
// This needs to be set before initializing the QApplication.
#if QT_VERSION >= QT_VERSION_CHECK(5, 6, 0)
QApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
QApplication::setAttribute(Qt::AA_UseHighDpiPixmaps);
#endif
// Setting the organization name results in a QDesktopStorage::DataLocation
// of "$HOME/Library/Application Support/Mixxx/Mixxx" on OS X. Leave the
// organization name blank.
//QCoreApplication::setOrganizationName("Mixxx");
QCoreApplication::setApplicationName(Version::applicationName());
QCoreApplication::setApplicationVersion(Version::version());
// Construct a list of strings based on the command line arguments
CmdlineArgs& args = CmdlineArgs::Instance();
if (!args.Parse(argc, argv)) {
args.printUsage();
return kParseCmdlineArgsErrorExitCode;
}
// If you change this here, you also need to change it in
// ErrorDialogHandler::errorDialog(). TODO(XXX): Remove this hack.
QThread::currentThread()->setObjectName("Main");
// Create the ErrorDialogHandler in the main thread, otherwise it will be
// created in the thread of the first caller to instance(), which may not be
// the main thread. Bug #1748636.
ErrorDialogHandler::instance();
mixxx::Logging::initialize(args.getSettingsPath(),
args.getLogLevel(),
args.getLogFlushLevel(),
args.getDebugAssertBreak());
MixxxApplication app(argc, argv);
VERIFY_OR_DEBUG_ASSERT(SoundSourceProxy::registerProviders()) {
qCritical() << "Failed to register any SoundSource providers";
return kFatalErrorOnStartupExitCode;
}
#ifdef __APPLE__
QDir dir(QApplication::applicationDirPath());
// Set the search path for Qt plugins to be in the bundle's PlugIns
// directory, but only if we think the mixxx binary is in a bundle.
if (dir.path().contains(".app/")) {
// If in a bundle, applicationDirPath() returns something formatted
// like: .../Mixxx.app/Contents/MacOS
dir.cdUp();
dir.cd("PlugIns");
qDebug() << "Setting Qt plugin search path to:" << dir.absolutePath();
// asantoni: For some reason we need to do setLibraryPaths() and not
// addLibraryPath(). The latter causes weird problems once the binary
// is bundled (happened with 1.7.2 when Brian packaged it up).
QApplication::setLibraryPaths(QStringList(dir.absolutePath()));
}
#endif
// When the last window is closed, terminate the Qt event loop.
QObject::connect(&app, &MixxxApplication::lastWindowClosed, &app, &MixxxApplication::quit);
int exitCode = runMixxx(&app, args);
qDebug() << "Mixxx shutdown complete with code" << exitCode;
mixxx::Logging::shutdown();
return exitCode;
}
|