qtecomplugins/examples/testapp/src/main.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 16 Apr 2010 15:51:22 +0300
changeset 1 2b40d63a9c3d
child 5 453da2cfceef
permissions -rw-r--r--
Revision: 201011 Kit: 201015

/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, version 2.1 of the License.
* 
* 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program.  If not, 
* see "http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html/".
*
* Description:
*
*/

#include <QtGui>

#include <QObject>
#include <QString>
#include <QList>

#include <xqplugin.h>
#include <xqpluginloader.h>
#include <xqplugininfo.h>

#include "qtracker.h"

#include <testplugininterface.h>

int main(int argc, char *argv[])
{
    QApplication app(argc, argv);
    QTracker::log("--- Start ---");
    QList<XQPluginInfo> impls;
    
    XQPluginLoader::listImplementations("org.nokia.mmdt.TestPlugin/1.0", impls);

    QTracker::log("list plugins:");
    
    for (int i=0; i<impls.size(); i++) {
        QTracker::log("plugin found...");
        QString fmtStr("%1: %2");
        QTracker::log(fmtStr.arg("dll: ").arg(impls[i].dllName()));
        QTracker::log(fmtStr.arg("opaque data: ").arg(impls[i].opaqueData()));
        QTracker::log(fmtStr.arg("uid: ").arg(impls[i].uid()));
        QTracker::log("---");
    }

    XQPluginLoader pluginLoader;
    pluginLoader.setUid(0xE1253163);
    
    QObject *plugin = pluginLoader.instance();

    QString pluginFmt("Plugin instance: %1");
    QTracker::log(pluginFmt.arg(reinterpret_cast<int>(plugin)));

    TestPluginInterface *pluginCast = qobject_cast<TestPluginInterface*>(plugin);
    QTracker::log(pluginFmt.arg(reinterpret_cast<int>(pluginCast)));


    if (pluginCast!=0)
    	QTracker::log(pluginFmt.arg(pluginCast->test()));
    
    QTracker::log("--- Stop ---");
//    return app.exec();
}