4d2ce949b3
Change tracing from qDebug() to use cutelogger, which is available under the LGPL2.1. This allows to automatically add filename and line number to the log, and also provides multiple log levels. Change-Id: I5dbdaf902ba54ea99f07ae10a07467c52fdac910
98 lines
3.7 KiB
C++
98 lines
3.7 KiB
C++
/***************************************************************************
|
|
* __________ __ ___.
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
* \/ \/ \/ \/ \/
|
|
*
|
|
* Copyright (C) 2007 by Dominik Riebeling
|
|
*
|
|
* All files in this archive are subject to the GNU General Public License.
|
|
* See the file COPYING in the source tree root for full license agreement.
|
|
*
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
* KIND, either express or implied.
|
|
*
|
|
****************************************************************************/
|
|
|
|
|
|
#include <QCoreApplication>
|
|
#include <QSettings>
|
|
#include "rbutilqt.h"
|
|
#include "systrace.h"
|
|
#include "Logger.h"
|
|
#include "ConsoleAppender.h"
|
|
#include "FileAppender.h"
|
|
|
|
#ifdef STATIC
|
|
#include <QtPlugin>
|
|
Q_IMPORT_PLUGIN(qtaccessiblewidgets)
|
|
#endif
|
|
|
|
|
|
int main( int argc, char ** argv ) {
|
|
QApplication app( argc, argv );
|
|
ConsoleAppender* consoleAppender = new ConsoleAppender();
|
|
consoleAppender->setFormat("[%f:%i %L] %m\n");
|
|
Logger::registerAppender(consoleAppender);
|
|
SysTrace::rotateTrace();
|
|
QString tracefile = QDir::tempPath() + "/rbutil-trace.log";
|
|
FileAppender* fileAppender = new FileAppender();
|
|
fileAppender->setFormat("[%f:%i %L] %m\n");
|
|
fileAppender->setFileName(tracefile);
|
|
Logger::registerAppender(fileAppender);
|
|
LOG_INFO() << "Starting trace at" << QDateTime::currentDateTime().toString(Qt::ISODate);
|
|
|
|
#if defined(Q_OS_MAC)
|
|
QDir dir(QApplication::applicationDirPath());
|
|
dir.cdUp();
|
|
dir.cd("plugins");
|
|
QApplication::addLibraryPath(dir.absolutePath());
|
|
#endif
|
|
QString absolutePath = QCoreApplication::instance()->applicationDirPath();
|
|
// portable installation:
|
|
// check for a configuration file in the program folder.
|
|
QSettings *user;
|
|
if(QFileInfo(absolutePath + "/RockboxUtility.ini").isFile())
|
|
user = new QSettings(absolutePath + "/RockboxUtility.ini", QSettings::IniFormat, 0);
|
|
else user = new QSettings(QSettings::IniFormat, QSettings::UserScope, "rockbox.org", "RockboxUtility");
|
|
|
|
QString applang = QLocale::system().name();
|
|
QTranslator translator;
|
|
QTranslator qttrans;
|
|
// install translator
|
|
if(!user->value("lang", "").toString().isEmpty()) {
|
|
applang = user->value("lang", "").toString();
|
|
}
|
|
if(!applang.isEmpty()) {
|
|
if(!translator.load("rbutil_" + applang, absolutePath))
|
|
translator.load("rbutil_" + applang, ":/lang");
|
|
if(!qttrans.load("qt_" + applang,
|
|
QLibraryInfo::location(QLibraryInfo::TranslationsPath)))
|
|
qttrans.load("qt_" + applang, ":/lang");
|
|
|
|
QLocale::setDefault(applang);
|
|
}
|
|
delete user;
|
|
app.installTranslator(&translator);
|
|
app.installTranslator(&qttrans);
|
|
//: This string is used to indicate the writing direction. Translate it
|
|
//: to "RTL" (without quotes) for RTL languages. Anything else will get
|
|
//: treated as LTR language.
|
|
if(QObject::tr("LTR") == "RTL")
|
|
app.setLayoutDirection(Qt::RightToLeft);
|
|
|
|
// keep a list of installed translators. Needed to be able uninstalling them
|
|
// later again (in case of translation changes)
|
|
QList<QTranslator*> translators;
|
|
translators.append(&translator);
|
|
translators.append(&qttrans);
|
|
RbUtilQt window(0);
|
|
RbUtilQt::translators = translators;
|
|
window.show();
|
|
|
|
// app.connect( &app, SIGNAL(lastWindowClosed()), &app, SLOT(quit()) );
|
|
return app.exec();
|
|
|
|
}
|