idlefw/inc/framework/aistateobserver.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 31 Mar 2010 22:04:35 +0300
branchRCL_3
changeset 51 15e4dd19031c
parent 9 d0529222e3f0
child 74 edd621764147
permissions -rw-r--r--
Revision: 201011 Kit: 201013

/*
* Copyright (c) 2008 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:  State Observer
*
*/


#ifndef _AISTATEOBSERVER_H
#define _AISTATEOBSERVER_H

// System includes

// User includes
#include <aifwdefs.h>

// Forward declarations
class THsPublisherInfo;

/**
 * State Observer
 * 
 * @ingroup group_aifw
 * @lib aifw.lib
 * @since S60 5.2
 */
class MAiStateObserver
    {
public:
    /**
     * State change notification.
     * 
     * @since S60 5.2
     * @param aReason State change.
     */
    virtual void NotifyStateChange( TAiFwState aState ) = 0;
    
    /**
     * Content publisher load request.
     * 
     * @since S60 5.2
     * @param aInfo Publisher Info, which describes the plugin to be loaded.
     * @param aReason Startup reason, which will be forwarded to the plugin.
     * @return Error code, KErrNone if succesfully loaded. 
     */
    virtual TInt NotifyLoadPlugin( const THsPublisherInfo& aInfo,
        TAiFwLoadReason aReason ) = 0;

    /**
     * Content publisher destroy request.
     * 
     * @since S60 5.2
     * @param aInfo Publisher Info, which describes the plugin to be destroyed.
     * @param aReason Shutdown reason, which will be forwarded to the plugin.
     */    
    virtual void NotifyDestroyPlugin( const THsPublisherInfo& aInfo,
        TAiFwDestroyReason aReason ) = 0;
    
    /**
     * Notifies to reload previously released plugins
     * 
     * @since S60 5.2
     */    
    virtual void NotifyReloadPlugins() = 0;
    
    /**
     * Notifies that defined ECom plugins should be released to enable
     * plugin upgrade
     * 
     * @since S60 5.2
     */
    virtual void NotifyReleasePlugins( const RArray<TUid>& aUidList ) = 0;
    
    };
    
#endif // _AISTATEOBSERVER_H

// End of file