/* Copyright © 2017 Hasan Yavuz Özderya This file is part of serialplot. serialplot is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. serialplot is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with serialplot. If not, see . */ #include #include #include #include "mainwindow.h" #include "tooltipfilter.h" #include "version.h" MainWindow* pMainWindow = nullptr; void messageHandler(QtMsgType type, const QMessageLogContext &context, const QString &msg) { QString logString; switch (type) { #if (QT_VERSION >= QT_VERSION_CHECK(5, 5, 0)) case QtInfoMsg: logString = "[Info] " + msg; break; #endif case QtDebugMsg: logString = "[Debug] " + msg; break; case QtWarningMsg: logString = "[Warning] " + msg; break; case QtCriticalMsg: logString = "[Error] " + msg; break; case QtFatalMsg: logString = "[Fatal] " + msg; break; } std::cerr << logString.toStdString() << std::endl; if (pMainWindow != nullptr) { // TODO: don't call MainWindow::messageHandler if window is destroyed pMainWindow->messageHandler(type, logString, msg); } if (type == QtFatalMsg) { __builtin_trap(); } } int main(int argc, char *argv[]) { QApplication a(argc, argv); QApplication::setApplicationName(PROGRAM_NAME); QApplication::setApplicationVersion(VERSION_STRING); qInstallMessageHandler(messageHandler); MainWindow w; pMainWindow = &w; ToolTipFilter ttf; a.installEventFilter(&ttf); // log application information qDebug() << "SerialPlot" << VERSION_STRING; qDebug() << "Revision" << VERSION_REVISION; w.show(); return a.exec(); }