1
mirror of https://invent.kde.org/network/falkon.git synced 2024-09-22 18:22:10 +02:00
falkonOfficial/src/main/main.cpp

197 lines
5.8 KiB
C++
Raw Normal View History

2011-03-03 18:29:20 +01:00
/* ============================================================
* QupZilla - WebKit based browser
* Copyright (C) 2010-2013 David Rosca <nowrep@gmail.com>
2011-03-03 18:29:20 +01:00
*
* This program 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.
*
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
* ============================================================ */
2011-03-02 16:57:41 +01:00
#include "mainapplication.h"
#include "proxystyle.h"
2011-03-02 16:57:41 +01:00
#include <QMessageBox> // For QT_REQUIRE_VERSION
#if defined(Q_OS_LINUX) || defined(__GLIBC__)
#include <iostream>
#include <signal.h>
#include <execinfo.h>
#include "qupzilla.h"
#include <QDir>
#include <QDateTime>
#include <QTextStream>
#if QT_VERSION >= 0x050000
#include <QWebPage>
#else
#include "qwebkitversion.h"
#endif
void qupzilla_signal_handler(int s)
{
switch (s) {
case SIGPIPE:
// When using QtWebKit 2.2 and running QupZilla with gdb, I have experienced
// some SIGPIPEs so far (not with other versions, only with this).
// But every time, QupZilla was running fine after SIGPIPE, so we are catching
// this signal and ignoring it to prevent unneeded crash because of it.
std::cout << "QupZilla: Caught SIGPIPE!" << std::endl;
break;
case SIGSEGV: {
static bool sigSegvServed = false;
if (sigSegvServed) {
abort();
}
sigSegvServed = true;
std::cout << "QupZilla: Crashed :( Saving backtrace in " << qPrintable(mApp->PROFILEDIR) << "crashlog ..." << std::endl;
void* array[100];
int size = backtrace(array, 100);
char** strings = backtrace_symbols(array, size);
if (size < 0 || !strings) {
std::cout << "Cannot get backtrace!" << std::endl;
abort();
}
QDir dir(mApp->PROFILEDIR);
if (!dir.exists()) {
std::cout << qPrintable(mApp->PROFILEDIR) << " does not exist" << std::endl;
abort();
}
if (!dir.cd("crashlog")) {
if (!dir.mkdir("crashlog")) {
std::cout << "Cannot create " << qPrintable(mApp->PROFILEDIR) << "crashlog directory!" << std::endl;
abort();
}
dir.cd("crashlog");
}
const QDateTime currentDateTime = QDateTime::currentDateTime();
QFile file(dir.absoluteFilePath("Crash-" + currentDateTime.toString(Qt::ISODate) + ".txt"));
if (!file.open(QFile::WriteOnly | QFile::Truncate)) {
std::cout << "Cannot open file " << qPrintable(file.fileName()) << " for writing!" << std::endl;
abort();
}
QTextStream stream(&file);
stream << "Time: " << currentDateTime.toString() << endl;
stream << "Qt version: " << qVersion() << " (compiled with " << QT_VERSION_STR << ")" << endl;
stream << "QupZilla version: " << QupZilla::VERSION << endl;
stream << "WebKit version: " << qWebKitVersion() << endl;
stream << endl;
stream << "============== BACKTRACE ==============" << endl;
for (int i = 0; i < size; ++i) {
stream << "#" << i << ": " << strings[i] << endl;
}
file.close();
std::cout << "Backtrace successfuly saved in " << qPrintable(dir.absoluteFilePath(file.fileName())) << std::endl;
}
default:
break;
}
}
#endif // defined(Q_OS_LINUX) || defined(__GLIBC__)
#ifndef Q_OS_WIN
2013-02-18 13:37:12 +01:00
#if (QT_VERSION < 0x050000)
void msgHandler(QtMsgType type, const char* msg)
{
// Skip this debug message as it may occur in a large amount over time
if (strcmp("QFont::setPixelSize: Pixel size <= 0 (0)", msg) == 0) {
return;
}
switch (type) {
case QtDebugMsg:
case QtWarningMsg:
case QtCriticalMsg:
std::cerr << msg << std::endl;
break;
case QtFatalMsg:
std::cerr << "Fatal: " << msg << std::endl;
abort();
default:
break;
}
}
2013-02-18 13:37:12 +01:00
#else
void msgHandler(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
QByteArray localMsg = msg.toLocal8Bit();
switch (type) {
case QtDebugMsg:
case QtWarningMsg:
case QtCriticalMsg:
std::cerr << localMsg.constData() << " (" << context.file << ":" << context.line << ", " << context.function << ")" << std::endl;
2013-02-18 13:37:12 +01:00
break;
case QtFatalMsg:
std::cerr << "Fatal: " << localMsg.constData() << " (" << context.file << ":" << context.line << ", " << context.function << ")" << std::endl;
2013-02-18 13:37:12 +01:00
abort();
2013-02-18 13:37:12 +01:00
default:
break;
}
}
#endif
#endif
int main(int argc, char* argv[])
2011-03-02 16:57:41 +01:00
{
QT_REQUIRE_VERSION(argc, argv, "4.7.0");
2013-02-18 13:37:12 +01:00
#ifndef Q_OS_WIN
2013-02-18 13:37:12 +01:00
#if (QT_VERSION < 0x050000)
qInstallMsgHandler(&msgHandler);
2013-02-18 13:37:12 +01:00
#else
qInstallMessageHandler(&msgHandler);
#endif
#endif
2012-12-22 12:47:45 +01:00
#if defined(QZ_WS_X11) && QT_VERSION < 0x050000
2011-03-02 16:57:41 +01:00
QApplication::setGraphicsSystem("raster"); // Better overall performance on X11
#endif
#if defined(Q_OS_LINUX) || defined(__GLIBC__)
signal(SIGSEGV, qupzilla_signal_handler);
signal(SIGPIPE, qupzilla_signal_handler);
2011-03-02 16:57:41 +01:00
#endif
MainApplication app(argc, argv);
if (app.isClosing()) {
// Not showing any output, otherwise XFCE shows "Failed to execute default browser. I/O error" error
// if (argc == 1) {
// std::cout << "QupZilla already running - activating existing window" << std::endl;
// }
return 0;
2011-03-24 16:51:19 +01:00
}
app.setProxyStyle(new ProxyStyle);
return app.exec();
2011-03-02 16:57:41 +01:00
}