graphicsapitest/graphicssvs/wserv/src/T_DataWindowGroup.cpp
author Gareth Stockwell <gareth.stockwell@accenture.com>
Fri, 22 Oct 2010 11:59:21 +0100
branchbug235_bringup_0
changeset 208 7df094ed4a3f
parent 0 5d03bc08d59c
permissions -rw-r--r--
Added a timer which kills eglbringuptest.exe after a short delay This is to allow the app to be used on a real device. Because it is a console app, there is no way to kill the application once it is running.

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

#include "T_DataWindowGroup.h"
#include "T_GraphicsUtil.h"

/*@{*/
_LIT(KDataClassname,	"RWindowGroup");

// Fields
_LIT(KFldAdjust					,"adjust");
_LIT(KFldCaptureKey				,"capturekey");
_LIT(KFldClientHandle			,"clienthandle");
_LIT(KFldClipRect				,"cliprect");
_LIT(KFldCursor					,"cursor");
_LIT(KFldDeviceNumber			,"devicenumber");
_LIT(KFldFlags					,"flags");
_LIT(KFldIdOfParentWindowGroup	,"idofparentwindowgroup");
_LIT(KFldInputKeyCode			,"inputkeycode");
_LIT(KFldIsFocusable			,"isfocusable");
_LIT(KFldKeycode				,"keycode");
_LIT(KFldModifier				,"modifier");
_LIT(KFldModifierMask			,"modifiermask");
_LIT(KFldOrdinalPriority		,"ordinalpriority");
_LIT(KFldOutputKeyCode			,"outputkeycode");
_LIT(KFldPos					,"pos");
_LIT(KFldProcessSID				,"processsid");
_LIT(KFldPriority				,"priority");
_LIT(KFldRepeatTime				,"repeattime");
_LIT(KFldScanCode				,"scancode");
_LIT(KFldScreenDevice			,"screendevice");
_LIT(KFldState					,"state");
_LIT(KFldStdScanCode			,"stdscancode");
_LIT(KFldTip					,"tip");
_LIT(KFldType					,"type");
_LIT(KFldWin					,"win");
_LIT(KFldWs						,"ws");
_LIT(KFldID						,"id");
_LIT(KFldIDName					,"id_name");

//Parameters
_LIT(KinputWGN,					"inputWGN");
_LIT(KexpectedReturnWGN,		"expectRtnWGN");
_LIT(KOwningWGIdentifier,		"OwningWGId");
_LIT(KOwningWGIdName,			"OwningWGId_name");

//Commands
_LIT(KCmdnew,									"new");
_LIT(KCmdDestructor,							"~");
_LIT(KCmdConstruct,								"Construct");
_LIT(KCmdConstructChildApp,						"ConstructChildApp");
_LIT(KCmdAllowProcessToCreateChildWindowGroups,	"AllowProcessToCreateChildWindowGroups");
_LIT(KCmdEnableReceiptOfFocus,					"EnableReceiptOfFocus");
_LIT(KCmdAutoForeground,						"AutoForeground");
_LIT(KCmdSetOrdinalPriorityAdjust,				"SetOrdinalPriorityAdjust");
_LIT(KCmdSetOrdinalPositionErr,					"SetOrdinalPositionErr");
_LIT(KCmdCaptureKey,							"CaptureKey");
_LIT(KCmdCancelCaptureKey,						"CancelCaptureKey");
_LIT(KCmdCaptureKeyUpAndDowns,					"CaptureKeyUpAndDowns");
_LIT(KCmdCancelCaptureKeyUpAndDowns,			"CancelCaptureKeyUpAndDowns");
_LIT(KCmdCaptureLongKey,						"CaptureLongKey");
_LIT(KCmdCancelCaptureLongKey,					"CancelCaptureLongKey");
_LIT(KCmdAddPriorityKey,						"AddPriorityKey");
_LIT(KCmdRemovePriorityKey,						"RemovePriorityKey");
_LIT(KCmdSetTextCursor,							"SetTextCursor");
_LIT(KCmdCancelTextCursor,						"CancelTextCursor");
_LIT(KCmdSetOwningWindowGroup,					"SetOwningWindowGroup");
_LIT(KCmdDefaultOwningWindow,					"DefaultOwningWindow");
_LIT(KCmdSetName,								"SetName");
_LIT(KCmdName,									"Name");
_LIT(KCmdIdentifier,							"Identifier");
_LIT(KCmdDisableKeyClick,						"DisableKeyClick");
_LIT(KCmdEnableScreenChangeEvents,				"EnableScreenChangeEvents");
_LIT(KCmdDisableScreenChangeEvents,				"DisableScreenChangeEvents");
_LIT(KCmdSimulatePointerEvent,					"SimulatePointerEvent");
_LIT(KCmdSetChildGroup,							"SetChildGroup");
_LIT(KCmdClearChildGroup,						"ClearChildGroup");

///	Logging
_LIT(KLogError,									"Error=%d");
_LIT(KLogMissingParameter,						"Missing parameter '%S'");
_LIT(KLogMissingExpectedValue,					"Missing expected value '%S'");
_LIT(KLogNotExpectedValueString,				"'%S' is not as expected='%S', actual='%S'");
/*@}*/

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CT_DataWindowGroup* CT_DataWindowGroup::NewL()
	{
	CT_DataWindowGroup*	ret=new (ELeave) CT_DataWindowGroup();
	CleanupStack::PushL(ret);
	ret->ConstructL();
	CleanupStack::Pop(ret);
	return ret;
	}

CT_DataWindowGroup::CT_DataWindowGroup()
:	CT_DataWindowTreeNode()
,	iWindowGroup(NULL)
,	iCaptureKeyHandle(0)
	{
	}

void CT_DataWindowGroup::ConstructL()
	{
	}

CT_DataWindowGroup::~CT_DataWindowGroup()
	{
	DestroyData();
	}

void CT_DataWindowGroup::SetObjectL(TAny* aAny)
	{
	DestroyData();
	iWindowGroup = static_cast<RWindowGroup*> (aAny);
	}

void CT_DataWindowGroup::DisownObjectL()
	{
	iWindowGroup = NULL;
	}

void CT_DataWindowGroup::DestroyData()
	{
	delete iWindowGroup;
	iWindowGroup=NULL;
	}

RWindowTreeNode* CT_DataWindowGroup::GetWindowTreeNode() const
	{
	return iWindowGroup;
	}

/**
* Process a command read from the ini file
*
* @param aCommand			the command to process
* @param aSection			the entry in the ini file requiring the command to be processed
* @param aAsyncErrorIndex	index of command. used for async calls
*
* @return ETrue if the command is processed
*/
TBool CT_DataWindowGroup::DoCommandL(const TTEFFunction& aCommand, const TTEFSectionName& aSection, const TInt aAsyncErrorIndex)
	{
	TBool	ret = ETrue;

	if ( aCommand==KCmdDestructor )
		{
		DoCmdDestructor();
		}
	else if ( aCommand==KCmdnew || aCommand==KDataClassname )
		{
		DoCmdnewL(aSection);
		}
	else if ( aCommand==KCmdConstruct )
		{
		DoCmdConstructL(aSection);
		}
	else if ( aCommand==KCmdConstructChildApp )
		{
		DoCmdConstructChildAppL(aSection);
		}
	else if ( aCommand==KCmdAllowProcessToCreateChildWindowGroups )
		{
		DoCmdAllowProcessToCreateChildWindowGroups(aSection);
		}
	else if ( aCommand==KCmdEnableReceiptOfFocus )
		{
		DoCmdEnableReceiptOfFocus(aSection);
		}
	else if ( aCommand==KCmdAutoForeground )
		{
		DoCmdAutoForeground(aSection);
		}
	else if ( aCommand==KCmdSetOrdinalPriorityAdjust )
		{
		DoCmdSetOrdinalPriorityAdjust(aSection);
		}
	else if ( aCommand==KCmdSetOrdinalPositionErr )
		{
		DoCmdSetOrdinalPositionErr(aSection);
		}
	else if ( aCommand==KCmdCaptureKey )
		{
		DoCmdCaptureKey(aSection);
		}
	else if ( aCommand==KCmdCancelCaptureKey )
		{
		DoCmdCancelCaptureKey(aSection);
		}
	else if ( aCommand==KCmdCaptureKeyUpAndDowns )
		{
		DoCmdCaptureKeyUpAndDowns(aSection);
		}
	else if ( aCommand==KCmdCancelCaptureKeyUpAndDowns )
		{
		DoCmdCancelCaptureKeyUpAndDowns(aSection);
		}
	else if ( aCommand==KCmdCaptureLongKey )
		{
		DoCmdCaptureLongKey(aSection);
		}
	else if ( aCommand==KCmdCancelCaptureLongKey )
		{
		DoCmdCancelCaptureLongKey(aSection);
		}
	else if ( aCommand==KCmdAddPriorityKey )
		{
		DoCmdAddPriorityKey(aSection);
		}
	else if ( aCommand==KCmdRemovePriorityKey )
		{
		DoCmdRemovePriorityKey(aSection);
		}
	else if ( aCommand==KCmdSetTextCursor )
		{
		DoCmdSetTextCursorL(aSection);
		}
	else if ( aCommand==KCmdCancelTextCursor )
		{
		DoCmdCancelTextCursor();
		}
	else if ( aCommand==KCmdSetOwningWindowGroup )
		{
		DoCmdSetOwningWindowGroupL(aSection);
		}
	else if ( aCommand==KCmdDefaultOwningWindow )
		{
		DoCmdDefaultOwningWindow();
		}
	else if ( aCommand==KCmdSetName )
		{
		DoCmdSetName(aSection);
		}
	else if ( aCommand==KCmdName )
		{
		DoCmdName(aSection);
		}
	else if ( aCommand==KCmdIdentifier )
		{
		DoCmdIdentifier();
		}
	else if ( aCommand==KCmdDisableKeyClick )
		{
		DoCmdDisableKeyClick(aSection);
		}
	else if ( aCommand==KCmdEnableScreenChangeEvents )
		{
		DoCmdEnableScreenChangeEvents();
		}
	else if ( aCommand==KCmdDisableScreenChangeEvents )
		{
		DoCmdDisableScreenChangeEvents();
		}
	else if ( aCommand==KCmdSimulatePointerEvent )
		{
		DoCmdSimulatePointerEvent(aSection);
		}
	else if ( aCommand==KCmdSetChildGroup )
		{
		DoCmdSetChildGroupL(aSection);
		}
	else if ( aCommand==KCmdClearChildGroup )
		{
		DoCmdClearChildGroup();
		}
	else
		{
		ret=CT_DataWindowTreeNode::DoCommandL(aCommand, aSection, aAsyncErrorIndex);
		}

	return ret;
	}


void CT_DataWindowGroup::DoCmdnewL(const TDesC& aSection)
	{
	DestroyData();

	// Get test data for command input parameter(s)
	TPtrC	wsName;
	RWsSession* ws=NULL;
	if ( GetStringFromConfig(aSection, KFldWs, wsName) )
		{
		ws = static_cast<RWsSession*>(GetDataObjectL(wsName));
		}

	TInt	err=KErrNone;
	if ( ws!=NULL )
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute new RWindowGroup(RWsSession)"));
		TRAP( err, iWindowGroup = new (ELeave) RWindowGroup(*ws));
		}
	else
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute new RWindowGroup()"));
		TRAP( err, iWindowGroup = new (ELeave) RWindowGroup());
		}

	if ( err!=KErrNone )
		{
		ERR_PRINTF2(KLogError, err);
		SetError(err);
		}
	}


void CT_DataWindowGroup::DoCmdDestructor()
	{
	DestroyData();
	}


void CT_DataWindowGroup::DoCmdConstructL(const TDesC& aSection)
	{
	TInt	returnCode=KErrNone;

	// Get test data for command input parameter(s)
	TInt	datClientHandle;
	TBool	hasClientHandle = GetIntFromConfig(aSection, KFldClientHandle, datClientHandle);
	if ( !hasClientHandle )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldClientHandle);
		SetBlockResult(EFail);
		}
	else
		{
		TBool	datIsFocusable;
		TBool	hasIsFocusable = GetBoolFromConfig(aSection, KFldIsFocusable, datIsFocusable);

#if defined(SYMBIAN_WSERV_AND_CONE_MULTIPLE_SCREENS)
		CWsScreenDevice*	screenDevice=NULL;
		// Execute command and log parameters
		if ( CT_GraphicsUtil::GetWsScreenDeviceL(*this, aSection, KFldScreenDevice, screenDevice) )
			{
			if ( hasIsFocusable )
				{
				INFO_PRINTF1(_L("execute Construct(TUint32, TBool, CWsScreenDevice)"));
				returnCode = iWindowGroup->Construct(datClientHandle, datIsFocusable, screenDevice);
				}
			else
				{
				INFO_PRINTF1(_L("execute Construct(TUint32, CWsScreenDevice)"));
				returnCode = iWindowGroup->Construct(datClientHandle, screenDevice);
				}
			}
		else
#endif
			{
			if ( hasIsFocusable )
				{
				INFO_PRINTF1(_L("execute Construct(TUint32, TBool)"));
				returnCode = iWindowGroup->Construct(datClientHandle, datIsFocusable);
				}
			else
				{
				INFO_PRINTF1(_L("execute Construct(TUint32)"));
				returnCode = iWindowGroup->Construct(datClientHandle);
				}
			}
		}

	// Check the command return code, if !=KErrNone then stop this command
	if ( returnCode!=KErrNone )
		{
		ERR_PRINTF2(KLogError, returnCode);
		SetError(returnCode);
		}

	// No command output parameter to display and check
	}


void CT_DataWindowGroup::DoCmdConstructChildAppL(const TDesC& aSection)
	{
	TBool	dataOk=ETrue;
	TInt	returnCode=KErrNone;

	// Get test data for command input parameter(s)
	TInt	datIdOfParentWindowGroup;
	if ( !GetIntFromConfig(aSection, KFldIdOfParentWindowGroup, datIdOfParentWindowGroup) )
		{
		CDataWrapperBase*	wrapper=NULL;
		TPtrC	objectName;
		if ( GetStringFromConfig(aSection, KFldIdOfParentWindowGroup(), objectName) )
			{
			wrapper=static_cast<CDataWrapperBase*>(GetDataWrapperL(objectName));

			}
		
		if ( wrapper==NULL )
			{
			dataOk=EFalse;
			ERR_PRINTF2(KLogMissingParameter, &KFldIdOfParentWindowGroup);
			SetBlockResult(EFail);
			}
		else
			{
			datIdOfParentWindowGroup = wrapper->GetIdentifier();
			}
		}

	TInt	datClientHandle;
	if ( !GetIntFromConfig(aSection, KFldClientHandle, datClientHandle) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldClientHandle);
		SetBlockResult(EFail);
		}

	if ( dataOk )
		{
		TBool	datIsFocusable;
		if ( GetBoolFromConfig(aSection, KFldIsFocusable, datIsFocusable) )
			{
			// Execute command and log parameters
			INFO_PRINTF1(_L("execute ConstructChildApp(TInt, TUint32, TBool)"));
			returnCode = iWindowGroup->ConstructChildApp(datIdOfParentWindowGroup, datClientHandle, datIsFocusable);
			}
		else
			{
			// Execute command and log parameters
			INFO_PRINTF1(_L("execute ConstructChildApp(TInt, TUint32)"));
			returnCode = iWindowGroup->ConstructChildApp(datIdOfParentWindowGroup, datClientHandle);
			}

		// Check the command return code, if !=KErrNone then stop this command
		if ( returnCode!=KErrNone )
			{
			ERR_PRINTF2(KLogError, returnCode);
			SetError(returnCode);
			}

		// No command output parameter to display and check
		}
	}


void CT_DataWindowGroup::DoCmdAllowProcessToCreateChildWindowGroups(const TDesC& aSection)
	{
	// Get test data for command input parameter(s)
	TInt	datProcess;
	if ( !GetIntFromConfig(aSection, KFldProcessSID, datProcess) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldProcessSID);
		SetBlockResult(EFail);
		}
	else
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute AllowProcessToCreateChildWindowGroups(TUid)"));
		iWindowGroup->AllowProcessToCreateChildWindowGroups(TUid::Uid(datProcess));
		}

	// No command return value and output parameter to display and check
	}


void CT_DataWindowGroup::DoCmdEnableReceiptOfFocus(const TDesC& aSection)
	{
	// Get test data for command input parameter(s)
	TBool	datState;
	if ( !GetBoolFromConfig(aSection, KFldState, datState) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldState);
		SetBlockResult(EFail);
		}
	else
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute EnableReceiptOfFocus(TBool)"));
		iWindowGroup->EnableReceiptOfFocus(datState);
		}

	// No command return value and output parameter to display and check
	}


void CT_DataWindowGroup::DoCmdAutoForeground(const TDesC& aSection)
	{
	// Get test data for command input parameter(s)
	TBool	datState;
	if ( !GetBoolFromConfig(aSection, KFldState, datState) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldState);
		SetBlockResult(EFail);
		}
	else
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute AutoForeground(TBool)"));
		iWindowGroup->AutoForeground(datState);
		}

	// No command return value and output parameter to display and check
	}


void CT_DataWindowGroup::DoCmdSetOrdinalPriorityAdjust(const TDesC& aSection)
	{
	// Get test data for command input parameter(s)
	TInt	datAdjust;
	if ( !GetIntFromConfig(aSection, KFldAdjust, datAdjust) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldAdjust);
		SetBlockResult(EFail);
		}
	else
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute SetOrdinalPriorityAdjust(TInt)"));
		iWindowGroup->SetOrdinalPriorityAdjust(datAdjust);
		}

	// No command return value and output parameter to display and check
	}


void CT_DataWindowGroup::DoCmdSetOrdinalPositionErr(const TDesC& aSection)
	{
	TBool	dataOk=ETrue;

	// Get test data for command input parameter(s)
	TInt	datPos;
	if ( !GetIntFromConfig(aSection, KFldPos, datPos) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldPos);
		SetBlockResult(EFail);
		}

	TInt	datOrdinalPriority;
	if ( !GetIntFromConfig(aSection, KFldOrdinalPriority, datOrdinalPriority) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldOrdinalPriority);
		SetBlockResult(EFail);
		}

	if ( dataOk )
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute SetOrdinalPositionErr(TInt, TInt)"));
		TInt	returnCode = iWindowGroup->SetOrdinalPositionErr(datPos, datOrdinalPriority);

		// Check the command return code, if !=KErrNone then stop this command
		if ( returnCode!=KErrNone )
			{
			ERR_PRINTF2(KLogError, returnCode);
			SetError(returnCode);
			}

		// No command output parameter to display and check
		}
	}

void CT_DataWindowGroup::DoCmdCaptureKey(const TDesC& aSection)
	{
	TBool	dataOk=ETrue;

	TKeyCode	keyCode;
	if ( !CT_GraphicsUtil::ReadKeyCode(*this, aSection, KFldKeycode, keyCode) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldKeycode);
		SetBlockResult(EFail);
		}

	TUint	modifierMask;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifierMask, modifierMask) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifierMask);
		SetBlockResult(EFail);
		}

	TUint	modifier;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifier, modifier) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifier);
		SetBlockResult(EFail);
		}

	if ( dataOk )
		{
		TInt	ret=KErrNone;
		TInt	priority;
		if ( GetIntFromConfig(aSection, KFldPriority, priority) )
			{
			INFO_PRINTF1(_L("execute CaptureKey(keyCode, modifierMask, modifier, priority)"));
			ret=iWindowGroup->CaptureKey(keyCode, modifierMask, modifier, priority);
			}
		else
			{
			INFO_PRINTF1(_L("execute CaptureKey(keyCode, modifierMask, modifier)"));
			ret=iWindowGroup->CaptureKey(keyCode, modifierMask, modifier);
			}
		if ( ret<KErrNone )
			{
			ERR_PRINTF2(KLogError, ret);
			SetError(ret);
			}
		iCaptureKeyHandle=ret;
		}
	}


void CT_DataWindowGroup::DoCmdCancelCaptureKey(const TDesC& aSection)
	{
	// Get test data for command input parameter(s)
	TInt	captureKey;
	if ( !GetIntFromConfig(aSection, KFldCaptureKey, captureKey) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldCaptureKey);
		SetBlockResult(EFail);
		}
	else
		{
		INFO_PRINTF1(_L("execute CancelCaptureKey(captureKey)"));
		if ( captureKey == -1 )
			{
			iWindowGroup->CancelCaptureKey(iCaptureKeyHandle);
			}
		else
			{
			iWindowGroup->CancelCaptureKey(captureKey);
			}
		}
	}


void CT_DataWindowGroup::DoCmdCaptureKeyUpAndDowns(const TDesC& aSection)
	{
	TBool	dataOk=ETrue;

	TUint	scanCode;
	if ( !CT_GraphicsUtil::ReadStdScanCode(*this, aSection, KFldScanCode, (TStdScanCode&)scanCode) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldScanCode);
		SetBlockResult(EFail);
		}

	TUint	modifierMask;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifierMask, modifierMask) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifierMask);
		SetBlockResult(EFail);
		}

	TUint	modifier;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifier, modifier) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifier);
		SetBlockResult(EFail);
		}

	if ( dataOk )
		{
		TInt	ret=KErrNone;
		TInt	priority;
		if ( !GetIntFromConfig(aSection, KFldPriority, priority) )
			{
			INFO_PRINTF1(_L("execute CaptureKeyUpAndDowns(TUint, TUint, TUint)"));
			ret=iWindowGroup->CaptureKeyUpAndDowns(scanCode, modifierMask, modifier);
			}
		else
			{
			INFO_PRINTF1(_L("execute CaptureKeyUpAndDowns(TUint, TUint, TUint, TInt)"));
			ret=iWindowGroup->CaptureKeyUpAndDowns(scanCode, modifierMask, modifier, priority);
			}

		if ( ret < KErrNone )
			{
			ERR_PRINTF2(KLogError, ret);
			SetError(ret);
			} 
		else
			{
			iCaptureKeyHandle=ret;
			}
		}
	}


void CT_DataWindowGroup::DoCmdCancelCaptureKeyUpAndDowns(const TDesC& aSection)
	{
	// Get test data for command input parameter(s)
	TInt	captureKey;
	if ( !GetIntFromConfig(aSection, KFldCaptureKey, captureKey) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldCaptureKey);
		SetBlockResult(EFail);
		}
	else
		{
		INFO_PRINTF1(_L("execute CancelCaptureKeyUpAndDowns(captureKey)"));
		if ( captureKey == -1 )
			{
			iWindowGroup->CancelCaptureKeyUpAndDowns(iCaptureKeyHandle);
			}
		else
			{
			iWindowGroup->CancelCaptureKeyUpAndDowns(captureKey);
			}
		}
	}


void CT_DataWindowGroup::DoCmdCaptureLongKey(const TDesC& aSection)
	{
	TBool			dataOk=ETrue;

	TKeyCode	inputKeyCode;
	if ( !CT_GraphicsUtil::ReadKeyCode(*this, aSection, KFldInputKeyCode, inputKeyCode) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldInputKeyCode);
		SetBlockResult(EFail);
		}

	TKeyCode	outputKeyCode;
	if ( !CT_GraphicsUtil::ReadKeyCode(*this, aSection, KFldOutputKeyCode, outputKeyCode) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldOutputKeyCode);
		SetBlockResult(EFail);
		}

	TUint	modifierMask;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifierMask, modifierMask) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifierMask);
		SetBlockResult(EFail);
		}

	TUint	modifier;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifier, modifier) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifier);
		SetBlockResult(EFail);
		}

	TInt	priority;
	if ( !GetIntFromConfig(aSection, KFldPriority, priority) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldPriority);
		SetBlockResult(EFail);
		}

	TLongCaptureFlags	flags;
	if ( !CT_GraphicsUtil::ReadLongCaptureFlags(*this, aSection, KFldFlags, flags) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldFlags);
		SetBlockResult(EFail);
		}

	if ( dataOk )
		{
		TInt	ret=KErrNone;
		TInt	repeatTime;
		if ( GetIntFromConfig(aSection, KFldRepeatTime, repeatTime) )
			{
			TTimeIntervalMicroSeconds32	theRepeatTime(repeatTime);

			// Execute command and log parameters
			INFO_PRINTF1(_L("execute CaptureLongKey(repeatTime, inputKeyCode, iutputKeyCode, modifierMask, modifier, priority, flags)"));
			ret=iWindowGroup->CaptureLongKey(theRepeatTime, inputKeyCode, outputKeyCode, modifierMask, modifier, priority, flags);
			}
		else
			{
			// Execute command and log parameters
			INFO_PRINTF1(_L("execute CaptureLongKey(inputKeyCode, outputKeyCode, modifierMask, modifier, priority, flags)"));
			ret=iWindowGroup->CaptureLongKey(inputKeyCode, outputKeyCode, modifierMask, modifier, priority, flags);
			}

		// Check the command return code, if !=KErrNone then stop this command
		if ( ret<KErrNone )
			{
			ERR_PRINTF2(KLogError, ret);
			SetError(ret);
			}
		iCaptureKeyHandle=ret;
		}
	}


void CT_DataWindowGroup::DoCmdCancelCaptureLongKey(const TDesC& aSection)
	{
	// Get test data for command input parameter(s)
	TInt	captureKey;
	if ( !GetIntFromConfig(aSection, KFldCaptureKey, captureKey) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldCaptureKey);
		SetBlockResult(EFail);
		}
	else
		{
		INFO_PRINTF1(_L("execute CancelCaptureLongKey(captureKey)"));
		if ( captureKey == -1 )
			{
			iWindowGroup->CancelCaptureLongKey(iCaptureKeyHandle);
			}
		else
			{
			iWindowGroup->CancelCaptureLongKey(captureKey);
			}
		}
	}


void CT_DataWindowGroup::DoCmdAddPriorityKey(const TDesC& aSection)
	{
	TBool	dataOk=ETrue;

	// Get test data for command input parameter(s)
	TKeyCode	keyCode;
	if ( !CT_GraphicsUtil::ReadKeyCode(*this, aSection, KFldKeycode, keyCode) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldKeycode);
		SetBlockResult(EFail);
		}

	TUint	modifierMask;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifierMask, modifierMask) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifierMask);
		SetBlockResult(EFail);
		}

	TUint	modifier;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifier, modifier) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifier);
		SetBlockResult(EFail);
		}

	if ( dataOk )
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute AddPriorityKey(TUint, TUint, TUint)"));
		TInt	ret=iWindowGroup->AddPriorityKey(keyCode, modifierMask, modifier);

		// Check the command return code, if <KErrNone then stop this command
		if ( ret!=KErrNone )
			{
			ERR_PRINTF2(KLogError, ret);
			SetError(ret);
			}
		}
	}


void CT_DataWindowGroup::DoCmdRemovePriorityKey(const TDesC& aSection)
	{
	TBool	dataOk=ETrue;

	// Get test data for command input parameter(s)
	TKeyCode	keyCode;
	if ( !CT_GraphicsUtil::ReadKeyCode(*this, aSection, KFldKeycode, keyCode) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldKeycode);
		SetBlockResult(EFail);
		}

	TUint	modifierMask;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifierMask, modifierMask) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifierMask);
		SetBlockResult(EFail);
		}

	TUint	modifier;
	if ( !CT_GraphicsUtil::ReadEventModifier(*this, aSection, KFldModifier, modifier) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldModifier);
		SetBlockResult(EFail);
		}

	if ( dataOk )
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute RemovePriorityKey(TUint, TUint, TUint)"));
		iWindowGroup->RemovePriorityKey(keyCode, modifierMask, modifier);
		}
	}


void CT_DataWindowGroup::DoCmdSetTextCursorL(const TDesC& aSection)
	{
	TBool	dataOk=ETrue;

	TPtrC	datWinName;
	RWindowBase*	win = NULL;
	if ( !GetStringFromConfig(aSection, KFldWin, datWinName) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldWin);
		SetBlockResult(EFail);
		dataOk=EFalse;
		}
	else
		{
		win = static_cast<RWindowBase*>(GetDataObjectL(datWinName));
		}

	TPoint	datPos;
	if ( !GetPointFromConfig(aSection, KFldPos, datPos) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldPos);
		SetBlockResult(EFail);
		dataOk=EFalse;
		}

	TTextCursor	datCursor;
	if ( !CT_GraphicsUtil::GetTextCursor(*this, aSection, KFldCursor, datCursor) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldCursor);
		SetBlockResult(EFail);
		dataOk=EFalse;
		}

	if ( dataOk )
		{
		// get rectangle top left x-coordinate from parameters
		TRect	datClipRect;
		if ( GetRectFromConfig(aSection, KFldClipRect, datClipRect) )
			{
			INFO_PRINTF1(_L("execute SetTextCursor(RWindowBase, const TPoint, const TTextCursor, const TRect)"));
			iWindowGroup->SetTextCursor(*win, datPos, datCursor, datClipRect);
			}
		else
			{
			INFO_PRINTF1(_L("execute SetTextCursor(RWindowBase, const TPoint, const TTextCursor)"));
			iWindowGroup->SetTextCursor(*win, datPos, datCursor);
			}
		}
	}


void CT_DataWindowGroup::DoCmdCancelTextCursor()
	{
	INFO_PRINTF1(_L("RWindowGroup::CancelTextCursor() call"));
	iWindowGroup->CancelTextCursor();
	}


void CT_DataWindowGroup::DoCmdSetOwningWindowGroupL(const TDesC& aSection)
	{
	TInt	winGroupId=0;
	TBool	hasWGIdentifier=ETrue;

	if ( !GetIntFromConfig(aSection, KOwningWGIdentifier(), winGroupId) )
		{

		CDataWrapperBase*	wrapper=NULL;
		TPtrC	objectName;
		if ( GetStringFromConfig(aSection, KOwningWGIdName(), objectName) )
			{
			wrapper=static_cast<CDataWrapperBase*>(GetDataWrapperL(objectName));
			}
			
		if ( wrapper!=NULL )
			{
			winGroupId = wrapper->GetIdentifier();
			
			INFO_PRINTF2(_L("get id:%d"), winGroupId);
			}
		else
			{
			ERR_PRINTF2(KLogMissingParameter, &KOwningWGIdentifier);
			SetBlockResult(EFail);
			hasWGIdentifier = EFalse;
			}
		}

	if ( !hasWGIdentifier )
		{
		ERR_PRINTF2(KLogMissingParameter, &KOwningWGIdentifier);
		SetBlockResult(EFail);
		}
	else
		{
		INFO_PRINTF1(_L("execute SetOwningWindowGroup(TInt)"));
		iWindowGroup->SetOwningWindowGroup(winGroupId);
		}
	}


void CT_DataWindowGroup::DoCmdDefaultOwningWindow()
	{
	INFO_PRINTF1(_L("execute DefaultOwningWindow()"));
	iWindowGroup->DefaultOwningWindow();
	}


void CT_DataWindowGroup::DoCmdSetName(const TDesC& aSection)
	{
	TPtrC	theNameString;

	if ( !GetStringFromConfig(aSection, KinputWGN(), theNameString) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KinputWGN);
		SetBlockResult(EFail);
		}
	else
		{
		INFO_PRINTF1(_L("execute SetName(const TDesC)"));
		TInt	err = iWindowGroup->SetName(theNameString);

		if ( err!=KErrNone )
			{
			ERR_PRINTF2(KLogError, err);
			SetError(err);
			}
		}
	}

void CT_DataWindowGroup::DoCmdName(const TDesC& aSection)
	{
	TBuf<KMaxTestExecuteCommandLength>	storeBuffer;

	INFO_PRINTF1(_L("execute Name(TDes&)"));
	TInt	err = iWindowGroup->Name(storeBuffer);

	if ( err!=KErrNone )
		{
		ERR_PRINTF2(KLogError, err);
		SetError(err);
		}
	else
		{
		INFO_PRINTF2(_L("the length of  name:%d"), storeBuffer.Length());
		INFO_PRINTF1(_L("the name of window group:"));
		INFO_PRINTF1(storeBuffer);

		TPtrC	returnWGName;
		if ( !GetStringFromConfig(aSection, KexpectedReturnWGN(), returnWGName) )
			{
			ERR_PRINTF2(KLogMissingExpectedValue, &KexpectedReturnWGN());
			SetBlockResult(EFail);
			}
		else
			{
			if (storeBuffer!=returnWGName)
				{
				ERR_PRINTF4(KLogNotExpectedValueString, &KexpectedReturnWGN, &returnWGName, &storeBuffer);
				SetBlockResult(EFail);
				}
			}
		}
	}


void CT_DataWindowGroup::DoCmdIdentifier()
	{
	INFO_PRINTF1(_L("execute Identifier()"));
	TInt	actualWGId=iWindowGroup->Identifier();
	INFO_PRINTF2(_L("Identifier:%d"),actualWGId);
	SetIdentifier(actualWGId);
	}


void CT_DataWindowGroup::DoCmdDisableKeyClick(const TDesC& aSection)
	{
	// Get test data for command input parameter(s)
	TBool	datState;
	if ( !GetBoolFromConfig(aSection, KFldState, datState) )
		{
		ERR_PRINTF2(KLogMissingParameter, &KFldState);
		SetBlockResult(EFail);
		}
	else
		{
		// Execute command and log parameters
		INFO_PRINTF1(_L("execute DisableKeyClick(TBool)"));
		iWindowGroup->DisableKeyClick(datState);
		}

	// No command return value and output parameter to display and check
	}


void CT_DataWindowGroup::DoCmdEnableScreenChangeEvents()
	{
	INFO_PRINTF1(_L("execute EnableScreenChangeEvents()"));
	TInt err = iWindowGroup->EnableScreenChangeEvents();

	if ( err!=KErrNone )
		{
		ERR_PRINTF2(KLogError, err);
		SetError(err);
		}
	}


void CT_DataWindowGroup::DoCmdDisableScreenChangeEvents()
	{
	INFO_PRINTF1(_L("execute DisableScreenChangeEvents()"));
	iWindowGroup->DisableScreenChangeEvents();
	}


void CT_DataWindowGroup::DoCmdSimulatePointerEvent(const TDesC& aSection)
	{
	TBool		dataOk=ETrue;
	TRawEvent	event;

	TRawEvent::TType	type=TRawEvent::ENone;
	if ( !CT_GraphicsUtil::ReadType(*this, aSection, KFldType(), type) )
		{
		dataOk=EFalse;
		ERR_PRINTF2(KLogMissingParameter, &KFldType());
		SetBlockResult(EFail);
		}
	else
		{
		event.Set(type);
		}

	TStdScanCode	stdScanCode;
	if ( CT_GraphicsUtil::ReadStdScanCode(*this, aSection, KFldStdScanCode(), stdScanCode) )
		{
		event.Set(type, stdScanCode);
		}

	TInt	deviceNumber;
	if ( GetIntFromConfig(aSection, KFldDeviceNumber, deviceNumber) )
		{
		event.SetDeviceNumber(deviceNumber);
		}

	TPoint	pointerPos(0,0);
	if ( GetPointFromConfig(aSection, KFldPos, pointerPos) )
		{
		event.Set(type, pointerPos.iX, pointerPos.iY);
		}

	TBool	tip;
	if ( GetBoolFromConfig(aSection, KFldTip, tip) )
		{
		event.SetTip(tip);
		}

	if ( dataOk )
		{
		INFO_PRINTF1(_L("execute SimulatePointerEvent(TRawEvent)"));
		iWindowGroup->SimulatePointerEvent(event);
		}
	}


void CT_DataWindowGroup::DoCmdSetChildGroupL(const TDesC& aSection)
	{
	TBool	dataOk = ETrue;

	TInt	id;
	if ( !GetIntFromConfig(aSection, KFldID, id) )
		{
		CDataWrapperBase*	wrapper=NULL;
		TPtrC	objectName;
		if ( GetStringFromConfig(aSection, KFldIDName(), objectName) )
			{
			wrapper=static_cast<CDataWrapperBase*>(GetDataWrapperL(objectName));
			//handle=wrapper->GetHandle();
			}
			
		if ( wrapper!=NULL )
			{
			id = wrapper->GetIdentifier();
			
			INFO_PRINTF3(_L("get '%S_name' identifier = %d' to set child group"), &KFldID, id);
			}
		else
			{
			ERR_PRINTF2(KLogMissingParameter, &KFldID);
			SetBlockResult(EFail);
			dataOk = EFalse;
			}
		}

	if ( dataOk )
		{
		INFO_PRINTF1(_L("execute SetChildGroup(TInt)"));
		TInt	returnCode = iWindowGroup->SetChildGroup(id);

		if ( returnCode!=KErrNone )
			{
			ERR_PRINTF2(KLogError, returnCode);
			SetError(returnCode);
			}
		}
	}

void CT_DataWindowGroup::DoCmdClearChildGroup()
	{
	INFO_PRINTF1(_L("execute ClearChildGroup()"));
	TInt	returnCode = iWindowGroup->ClearChildGroup();

	if ( returnCode!=KErrNone )
		{
		ERR_PRINTF2(KLogError, returnCode);
		SetError(returnCode);
		}
	}