You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

85 lines
2.4 KiB
C++

/***************************************************************************
**
** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
** All rights reserved.
** Contact: Nokia Corporation (directui@nokia.com)
**
** This file is part of applauncherd
**
** If you have questions regarding the use of this file, please contact
** Nokia at directui@nokia.com.
**
** This library is free software; you can redistribute it and/or
** modify it under the terms of the GNU Lesser General Public
** License version 2.1 as published by the Free Software Foundation
** and appearing in the file LICENSE.LGPL included in the packaging
** of this file.
**
****************************************************************************/
#include <Qt/QtDeclarative>
#include <QFile>
#include <sys/time.h>
#include "mdeclarativecache.h"
QString log_file = "/tmp/fala_qml_helloworld.log";
void FANGORNLOG(const char* s)
{
QFile f(log_file);
f.open(QIODevice::Append);
f.write(s, qstrlen(s));
f.write("\n", 1);
f.close();
}
void timestamp(const char *s)
{
timeval tim;
char msg[80];
gettimeofday(&tim, NULL);
snprintf(msg, 80, "%d%03d %s",
static_cast<int>(tim.tv_sec), static_cast<int>(tim.tv_usec/1000), s);
FANGORNLOG(msg);
}
Q_DECL_EXPORT int main(int argc, char **argv)
{
QString appName(argv[0]);
if (appName.endsWith("fala_qml_wl"))
{
log_file = "/tmp/fala_qml_wl.log";
}
else if (appName.endsWith("fala_qml_wol"))
{
log_file = "/tmp/fala_qml_wol.log";
}
timestamp("application main");
QApplication *app = MDeclarativeCache::qApplication(argc, argv);
timestamp("QApplication from cache");
QDeclarativeView *window = MDeclarativeCache::qDeclarativeView();
timestamp("QDeclarativeView from cache");
QString d_path, f_path;
d_path = QString("applicationDirPath: ").append(QApplication::applicationDirPath());
const char * path_d = d_path.toStdString().c_str();
timestamp(path_d);
f_path = QString("applicationFilePath: ").append(QApplication::applicationFilePath());
const char * path_f = f_path.toStdString().c_str();
timestamp(path_f);
window->setWindowTitle("Applauncherd QML testapp");
window->setResizeMode(QDeclarativeView::SizeRootObjectToView);
window->setSource(QUrl::fromLocalFile("/usr/share/fala_qml_helloworld/main.qml"));
window->showFullScreen();
timestamp("Calling app->exec()");
_exit(app->exec());
}