/*
* 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