New version 0.4.6.
[dorian] / main.cpp
1 #include <QtGui/QApplication>
2
3 #include "mainwindow.h"
4 #include "trace.h"
5 #include "settings.h"
6 #include "library.h"
7 #include "settings.h"
8 #include "bookdb.h"
9 #include "search.h"
10 #include "platform.h"
11 #include "splash.h"
12
13 #ifdef Q_OS_SYMBIAN
14 #   include "mediakeysobserver.h"
15 #endif
16
17 static const char *DORIAN_VERSION =
18 #include "pkg/version.txt"
19 ;
20
21 static const QtMsgType DORIAN_DEFAULT_TRACE_LEVEL =
22 #ifdef Q_OS_SYMBIAN
23         QtDebugMsg
24 #else
25         QtWarningMsg
26 #endif
27         ;
28
29 int main(int argc, char *argv[])
30 {
31     int ret;
32
33     // Set up application
34     QApplication app(argc, argv);
35     app.setApplicationName("Dorian");
36     app.setApplicationVersion(DORIAN_VERSION);
37     app.setOrganizationDomain("pipacs.com");
38     app.setOrganizationName("Pipacs");
39
40     // Initialize tracing
41     Settings *settings = Settings::instance();
42     Trace::level = (QtMsgType)settings->
43         value("tracelevel", (int)DORIAN_DEFAULT_TRACE_LEVEL).toInt();
44     Trace::setFileName(settings->value("tracefilename").toString());
45     qInstallMsgHandler(Trace::messageHandler);
46
47     // Show splash screen
48     Splash splash;
49     splash.show();
50     app.processEvents();
51
52     // Initialize main window
53     MainWindow *mainWindow = new MainWindow();
54     settings->apply();
55     mainWindow->initialize();
56
57     // Hide splash screen
58     splash.finish(mainWindow);
59
60     // Run event loop, re-start application if event loop exit code was 1000
61     ret = app.exec();
62     if (ret == 1000) {
63         Platform::instance()->restart(argv);
64     }
65
66     // Release singletons
67     delete mainWindow;
68     Library::close();
69     BookDb::close();
70     Settings::close();
71     Search::close();
72     Platform::close();
73 #ifdef Q_OS_SYMBIAN
74     MediaKeysObserver::close();
75 #endif
76
77     return ret;
78 }