devicediagnostics/diagplugins/diagusbcableplugin/inc/diagusbcabletestplugin.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 08:40:12 +0200
changeset 0 3ce708148e4d
permissions -rw-r--r--
Revision: 200949 Kit: 200951

/*
* Copyright (c) 2007 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:  This is the header for the Diagnostics USB Cable Test Plug-in
*
*/




#ifndef DIAGUSBCABLETESTPLUGIN_H 
#define DIAGUSBCABLETESTPLUGIN_H

// INCLUDES

// System includes
#include <DiagResultsDatabaseItem.h>            // CDiagResultsDatabaseItem
#include <DiagTestPluginBase.h>                 // CDiagTestPluginBase

// User includes
#include "diagusbcabletestcallbackinterface.h"  // MDiagUSBTestCallBackInterface


//CONSTANTS

// MACROS

// DATA TYPES

// FUNCTION PROTOTYPES

// FORWARD DECLARATIONS
class CDiagResultsDbItemBuilder;
class CDiagUSBCableTestEngine;

// CLASS DEFINITION
class CDiagUSBCableTestPlugin : public CDiagTestPluginBase, 
                                public MDiagUSBTestCallBackInterface
    {
    
public: // Constructors and destructor

        /**
        * Symbian OS two-phased constructor
        * @return USB CableTest Test Plugin
        */
        static MDiagPlugin* NewL( TAny* aInitParams );

        /**
        * Destructor
        */
        ~CDiagUSBCableTestPlugin();

private: // from MDiagUSBTestCallBackInterface

        /**
        *  The USB Cable Test Engine calls this callback to provide the result of the test
        */
        void ReportTestResultL(CDiagResultsDatabaseItem::TResult aResult);
        
        /**
        * The engine class uses this callback on the plugin class to ask the user if the entire test
        * execution needs to be cancelled.
        * @param aUserResponse : The user response is returned in this reference argument.
        *      
        * @return ETrue     : The dialog was dismissed by the user.
        *         EFalse    : The dialog was dismissed internally.
        */    
        TBool AskCancelExecutionL(TInt& aUserResponse, TInt aOption);  

private: // From CDiagTestPluginBase

        /**
        * @see CDiagTestPluginBase::Visible()
        */
        TBool IsVisible() const;

        /**
        * @see CDiagTestPluginBase::RunMode()
        */
        TRunMode RunMode() const;

        /**
        * @see CDiagTestPluginBase::TotalSteps()
        */
        TUint TotalSteps() const;

        /**
        * @see CDiagTestPluginBase::GetPluginNameL
        */
        HBufC* GetPluginNameL( TNameLayoutType aLayoutType ) const;


        /**
        * @see CDiagTestPluginBase::Uid
        */
        TUid Uid() const;
        
        /**
        * Handle plug-in execution.
        * @see CDiagTestPluginBase::DoRunTestL
        */
        void DoRunTestL();

        /**
        * Clean up
        * @see CDiagTestPluginBase::DoStopAndCleanupL
        */
        void DoStopAndCleanupL();

private:    // private constructors

        /**
        * C++ default constructor.
        */
        CDiagUSBCableTestPlugin( CDiagPluginConstructionParam* aInitParams );

        /**
        * Symbian OS default constructor.
        *
        */
        void ConstructL();



private:    // from CActive
        /**
        * Handle active object completion event
        */
        void RunL();

        /**
        * Handle cancel
        */
        void DoCancel();

    private:    // private data
        
        /**
        * An instance of the engine class. Own
        */
        CDiagUSBCableTestEngine *iEngine;
    };

#endif //DIAGUSBCABLETESTPLUGIN_H

// End of File