tsrc/Apastub/inc/apgtask.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 11 Jun 2010 13:36:18 +0300
changeset 22 496ad160a278
parent 0 f0cf47e981f9
permissions -rw-r--r--
Revision: 201021 Kit: 2010123

/*
* Copyright (c) 1997-1999 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:
*
*/


#if !defined(__APGTASK_H__)
#define __APGTASK_H__

#if !defined(__E32BASE_H__)
#include <e32base.h>
#endif

#include <w32std.h>

class RWsSession;
struct TKeyEvent;

/** @internalTechnology */
static const TInt KApaSystemEventsWithPowerMgmtCapabilityStart = 100;
/** @internalTechnology */
static const TInt KApaSystemEventsWithPowerMgmtCapabilityEnd = 199;

/** Defines the event types that a TApaTask object can send to its window group.

The events are sent by TApaTask::SendSystemEvent() and are handled by CEikAppUi::HandleSystemEventL().

@publishedAll
@released
@see TApaTask::SendSystemEvent()
@see CEikAppUi
@see CCoeAppUi::HandleSystemEventL() */
enum TApaSystemEvent
    {
    /** The task is being closed. */
    EApaSystemEventShutdown=1,
    /** Reserved for future use. */
    EApaSystemEventBackupStarting,
    /** Reserved for future use. */
    EApaSystemEventBackupComplete,
    /** The task is being brought to the foreground. */
    EApaSystemEventBroughtToForeground,
    /** Close any tasks including system tasks.
    Events in the range @c KApaSystemEventsWithPowerMgmtCapabilityStart to
    @c KApaSystemEventsWithPowerMgmtCapabilityEnd requires capability PowerMgmt*/
    EApaSystemEventSecureShutdown = KApaSystemEventsWithPowerMgmtCapabilityStart
    };

#ifdef _UNICODE
/**
@publishedAll
@released
*/
#define KUidApaMessageSwitchOpenFile KUidApaMessageSwitchOpenFile16

/**
@publishedAll
@released
*/
#define KUidApaMessageSwitchCreateFile KUidApaMessageSwitchCreateFile16

/**
@publishedAll
@released
*/
#define KUidApaMessageSwitchOpenFileValue KUidApaMessageSwitchOpenFileValue16

/**
@publishedAll
@released
*/
#define KUidApaMessageSwitchCreateFileValue KUidApaMessageSwitchCreateFileValue16
#else
#define KUidApaMessageSwitchOpenFile KUidApaMessageSwitchOpenFile8
#define KUidApaMessageSwitchCreateFile KUidApaMessageSwitchCreateFile8
#define KUidApaMessageSwitchOpenFileValue KUidApaMessageSwitchOpenFileValue8
#define KUidApaMessageSwitchCreateFileValue KUidApaMessageSwitchCreateFileValue8
#endif

/**
@internalComponent
*/
const TInt KUidApaMessageSwitchOpenFileValue16=0x10003A39;

/**
@internalComponent
*/
const TUid KUidApaMessageSwitchOpenFile16={KUidApaMessageSwitchOpenFileValue16};

/**
@internalComponent
*/
const TInt KUidApaMessageSwitchCreateFileValue16=0x10003A3A;

/**
@internalComponent
*/
const TUid KUidApaMessageSwitchCreateFile16={KUidApaMessageSwitchCreateFileValue16};

class TApaTask
/** Application task.

A task is a running application. At any one time, for any given application,
there may be zero, one, or more tasks running on a device.

A task is identified by its association with the running application's window
group.

An instance of the TApaTaskList class is used to find and access specific
tasks.

@publishedAll
@released
@see TApaTaskList
@see RWindowGroup
@see RWsSession */
    {
public:

    IMPORT_C TApaTask(RWsSession& aWsSession);
    IMPORT_C void SetWgId(TInt aWgId);
    IMPORT_C TInt WgId() const;
    IMPORT_C TBool Exists();
    IMPORT_C TThreadId ThreadId() const;
    IMPORT_C void BringToForeground();
    IMPORT_C void SendToBackground();
    IMPORT_C void EndTask();
    IMPORT_C void KillTask();
    IMPORT_C void SendKey(TInt aKeyCode,TInt aModifiers);
    IMPORT_C void SendKey(const TKeyEvent& aKey);
    IMPORT_C void SendSystemEvent(TApaSystemEvent aEvent);
    IMPORT_C TInt SwitchOpenFile(const TDesC& aFilename);
    IMPORT_C TInt SwitchCreateFile(const TDesC& aFilename);
    IMPORT_C TInt SendMessage(TUid aUid, const TDesC8& aParams);

private:
    TInt CheckSwitchFile() const;
    void SendSystemEvent(TApaSystemEvent aEvent, TEventCode aType);

public: // Stubbed data
    RWsSession& iWsSession;
    TInt iWgId;
    TInt iTApaTask_Reserved1;

    enum KApaTaskCalledFunction
        {
        ENone, 
        EFindApp,
        EExists,
        EBringToForeground,
        ESendToBackground,
        EEndTask,
        EKillTask
        };
        


    static TBool iApplicationExist;        
    static TInt iApaTaskCalledFunction;


    };

class TApaTaskList
/** Accesses tasks running on a device.

Tasks can be identified by document, application specific UID or by caption
name.

Users of this class can also cycle through a set of tasks running a specific
application, bringing each one, in turn, into the foreground.

@publishedAll
@released
@see TApaTask */
    {
public:
    /** Defines the direction in which tasks are cycled to the foreground. This is used
    by the CycleTasks() function.

    @see TApaTaskList::CycleTasks() */
    enum TCycleDirection
        {
        /** Cycles the task list forwards, i.e. the foreground task is moved to background,
        bringing the next foremost task to the foreground. */
        EForwards,
        /** Cycles the list backwards, i.e. the task furthest from the foreground is brought
        to the foreground, pushing what was the foremost task to the next ordinal
        position. */
        EBackwards
        };
public:
    IMPORT_C TApaTaskList(RWsSession& aWsSession);
    IMPORT_C TApaTask FindApp(const TDesC& aAppName);
    IMPORT_C TApaTask FindDoc(const TDesC& aDocName);
    IMPORT_C TApaTask FindByPos(TInt aPos);
    IMPORT_C TApaTask FindApp(TUid aAppUid);
    IMPORT_C TInt CycleTasks(TUid aAppUid,TCycleDirection aDirection=EForwards);

private:
    void FindByPosL(TApaTask& aTask,TInt aPos);
public:
    RWsSession& iWsSession;
    TInt iTApaTaskList_Reserved1;
    
    enum KCalledFunction
        {
        ENone, 
        EFindApp
        };
        
    
    
    static TInt iCalledFunction;
    };


#endif