Fix tracing. Fix restoring previous position.
[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 a(argc, argv);
35     a.setApplicationName("Dorian");
36     a.setApplicationVersion(DORIAN_VERSION);
37     a.setOrganizationDomain("pipacs.com");
38     a.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 #ifdef Q_OS_SYMBIAN
48     // Show splash screen
49     Splash *splash = new Splash();
50     splash->showFullScreen();
51     a.processEvents();
52 #endif
53
54     // Create main window, run event loop
55     {
56         MainWindow w;
57 #ifdef Q_OS_SYMBIAN
58         splash->close();
59         splash->deleteLater();
60 #endif
61         ret = a.exec();
62     }
63
64     // Release singletons
65     Library::close();
66     BookDb::close();
67     Settings::close();
68     Search::close();
69 #ifdef Q_OS_SYMBIAN
70     MediaKeysObserver::close();
71 #endif
72
73     // Re-start application if event loop exit code was 1000
74     if (ret == 1000) {
75         Platform::restart(argv);
76     }
77     return ret;
78 }