ftuapplication/inc/ftufirsttimeuse.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 14 May 2010 15:42:45 +0300
changeset 3 0de9fa4800b7
parent 2 66c26770985f
child 7 446dc0e90e84
permissions -rw-r--r--
Revision: 201017 Kit: 201019

/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:  First Time Use application main class.
*
*/


#ifndef FTU_FIRSTTIMEUSE_H
#define FTU_FIRSTTIMEUSE_H

#include "ftutest_global.h"

#include <QObject>

FTU_TEST_CLASS(FtuFirstTimeUseTest)

class QStateMachine;
class XQSettingsManager;

/**
 * @ingroup group_ftuapplication
 * @brief First Time Use application main class.
 * 
 * Loads a runtime from a runtime provider plugin. Manages 
 * the runtime execution.
 *
 * @lib ?library
 * @since S60 ?S60_version
 */
class FtuFirstTimeUse : public QObject
{
    Q_OBJECT

public:

    /**
     * Constructor.
     * @since S60 ?S60_version.     
     * @param aParent Parent object.
     */
    FtuFirstTimeUse(QObject* aParent = 0);
    
    /**
     * Destructor.
     * @since S60 ?S60_version.     
     */
    virtual ~FtuFirstTimeUse();

private:

    /**
     * Registers service plugins pre-installed on the device.
     */
    void registerServicePlugins();
    /**
     * Recursively registers service plugins starting from given root
     * directory. All directories containing plugins are added to
     * application's library paths at the same time.
     * @param root The root folder.
     */
    void registerServicePlugins(const QString &root);

    Q_DISABLE_COPY(FtuFirstTimeUse)

signals:

    /**
     * Emitted when the FTU application needs to exit.
     * @since S60 ?S60_version.     
     */
    void exit();

public slots:

    /**
     * Starts the runtime.
     * @since S60 ?S60_version. 
     */
    void start();
    
    /**
     * Stops the runtime.
     * @since S60 ?S60_version.     
     */
    void stop();

private slots:

    /**
     * Called after the runtime has started.
     * @since S60 ?S60_version.     
     */
    void handleRuntimeStarted();

    /**
     * Called after the runtime has stopped.
     * @since S60 ?S60_version.     
     */
    void handleRuntimeStopped();
    
    /**
     * Called after the runtime has faulted.
     * @since S60 ?S60_version.     
     */
    void handleRuntimeFaulted();

private:

    /**
     * Runtime.
     */
    QStateMachine*     mRuntime;
    
    XQSettingsManager* mSettingsManager;

    FTU_TEST_FRIEND_CLASS(FtuFirstTimeUseTest)

};

#endif