Viadeo Twitter Google Bookmarks ! Facebook Digg del.icio.us MySpace Yahoo MyWeb Blinklist Netvouz Reddit Simpy StumbleUpon Bookmarks Windows Live Favorites 
Logo Documentation Qt ·  Page d'accueil  ·  Toutes les classes  ·  Toutes les fonctions  ·  Vues d'ensemble  · 

Tutorial: Writing server task plugin

Files:

The server task tutorial deomonstrates how to develop server task plugins. Server task plugins allow to dynamically extend the Qt Extended server even after the deployment process.

Plugin class definition

Each server task plugin must inherit from ServerTaskPlugin. It describes the various attributes of the task. During its startup phase the server loads all plugins which inherit from ServerTaskPlugin. Once it is time to actually start the server task provided by the plugin ServerTaskPlugin::initTask() is called which returns a reference to the new task object.

    #include <ServerTaskPlugin>

    class ExampleTaskPlugin : public ServerTaskPlugin
    {
        Q_OBJECT
    public:
        ExampleTaskPlugin( QObject* parent = 0 );
        virtual ~ExampleTaskPlugin();

        //name of task
        QByteArray name() const;

        //initialises task
        QObject* initTask( void* createArg = 0 ) const;

        //returns true if started in demand
        bool demand() const;
    };

Plugin class implementation

The implementation of the plugin class may look like this:

    ExampleTaskPlugin::ExampleTaskPlugin(QObject* parent)
        : ServerTaskPlugin( parent )
    {
    }

    ExampleTaskPlugin::~ExampleTaskPlugin()
    {
    }

    QByteArray ExampleTaskPlugin::name() const
    {
        return QByteArray("ExampleTask");
    }

    QObject* ExampleTaskPlugin::initTask(void* createArg ) const
    {
        Q_UNUSED( createArg );
        return new ExampleTask();
    }

    bool ExampleTaskPlugin::demand() const
    {
        return true;
    }

    QTOPIA_EXPORT_PLUGIN( ExampleTaskPlugin )

functiondescription
ServerTaskPlugin()The constructor is called immediately after startup of the server in order to identify all available server task plugins.
ServerTaskPlugin::initTask()Initialises/starts the task.
ServerTaskPlugin::name()This function returns the name of the task. This name may be used in conjunction with Task.cfg or QtopiaServerApplication::qtopiaTask().
ServerTaskPlugin::demand()If this function returns false this task will be started automatically unless otherwise specified byTask.cfg. If this function returns true this task is only started if another server task explicitly requests a reference to it.

The subsequent example task implementation does nothing and is only provided for the sake of completeness:

    #include "exampletask.h"
    #include <qtopiaglobal.h>

    #include <QDebug>

    class ExampleTask: public QObject
    {
    public:
        ExampleTask( QObject* parent = 0 ) : QObject(parent)
        {
            //server task code
        }

        ~ExampleTask()
        {
        }
    };

Limitations

Due to the fact that server task plugins don't have access to symbols in the server and vice versa some limitations apply:

  1. Plug-in task must inherit from QObject.
  2. Plug-in tasks do not have access to symbols in the Qt Extended server. Therefore it is not possible to obtain references to other server tasks via qtopiawidget<CLASS>() whereby CLASS is a class that is defined and declared in the server. Server tasks and plugin task can only refer to each other via QtopiaServerApplication::qtopiaTask() which returns a generic reference to a QObject. This means that server tasks provided via plugins must be self-contained.

Publicité

Best Of

Actualités les plus lues

Semaine
Mois
Année
  1. Les développeurs détestent-ils les antivirus ? Un programmeur manifeste sa haine envers ces solutions de sécurité 24
  2. «Le projet de loi des droits du développeur» : quelles conditions doivent remplir les entreprises pour que le développeur puisse réussir ? 46
  3. Une nouvelle ère d'IHM 3D pour les automobiles, un concept proposé par Digia et implémenté avec Qt 3
  4. Qt Creator 2.5 est sorti en beta, l'EDI supporte maintenant plus de fonctionnalités de C++11 2
  5. PySide devient un add-on Qt et rejoint le Qt Project et le modèle d'open gouvernance 1
  6. Vingt sociétés montrent leurs décodeurs basés sur Qt au IPTV World Forum, en en exploitant diverses facettes (déclaratif, Web, widgets) 0
  7. Thread travailleur avec Qt en utilisant les signaux et les slots, un article de Christophe Dumez traduit par Thibaut Cuvelier 1
  1. « Quelque chose ne va vraiment pas avec les développeurs "modernes" », un développeur à "l'ancienne" critique la multiplication des bibliothèques 95
  2. Apercevoir la troisième dimension ou l'utilisation multithreadée d'OpenGL dans Qt, un article des Qt Quarterly traduit par Guillaume Belz 0
  3. Pourquoi les programmeurs sont-ils moins payés que les gestionnaires de programmes ? Manquent-ils de pouvoir de négociation ? 50
  4. Les développeurs détestent-ils les antivirus ? Un programmeur manifeste sa haine envers ces solutions de sécurité 24
  5. «Le projet de loi des droits du développeur» : quelles conditions doivent remplir les entreprises pour que le développeur puisse réussir ? 46
  6. Quelles nouveautés de C++11 Visual C++ doit-il rapidement intégrer ? Donnez-nous votre avis 10
  7. Qt Commercial : Digia organise un webinar gratuit le 27 mars sur la conception d'interfaces utilisateur et d'applications avec le framework 0
Page suivante

Le blog Digia au hasard

Logo

Déploiement d'applications Qt Commercial sur les tablettes Windows 8

Le blog Digia est l'endroit privilégié pour la communication sur l'édition commerciale de Qt, où des réponses publiques sont apportées aux questions les plus posées au support. Lire l'article.

Communauté

Ressources

Liens utiles

Contact

  • Vous souhaitez rejoindre la rédaction ou proposer un tutoriel, une traduction, une question... ? Postez dans le forum Contribuez ou contactez-nous par MP ou par email (voir en bas de page).

Qt dans le magazine

Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. Qt qtextended4.4
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD.
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP !
 
 
 
 
Partenaires

Hébergement Web