graphicsapitest/graphicssvs/gdi/src/T_DataMeasureTextOutput.cpp
changeset 0 5d03bc08d59c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/graphicsapitest/graphicssvs/gdi/src/T_DataMeasureTextOutput.cpp	Tue Feb 02 01:47:50 2010 +0200
@@ -0,0 +1,348 @@
+/*
+* 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:
+*
+*/
+
+/**
+@test
+@internalComponent
+
+This contains CT_DataMeasureTextOutput
+*/
+
+#include "T_DataMeasureTextOutput.h"
+
+
+/*@{*/
+///	Parameters
+_LIT(KValue,									"value");
+_LIT(KRectAx,									"rect_ax");
+_LIT(KRectAy,									"rect_ay");
+_LIT(KRectBx,									"rect_bx");
+_LIT(KRectBy,									"rect_by");
+_LIT(KWidth,									"width");
+_LIT(KHeight,									"height");
+
+///	Commands
+_LIT(KCmdNew,									"new");
+_LIT(KCmdSetBounds,								"iBounds");
+_LIT(KCmdSetChars,								"iChars");
+_LIT(KCmdSetGlyphs,								"iGlyphs");
+_LIT(KCmdSetGroups,								"iGroups");
+_LIT(KCmdSetMaxGlyphSize,						"iMaxGlyphSize");
+_LIT(KCmdSetSpaces,								"iSpaces");
+_LIT(KCmdDestructor,							"~");
+
+
+
+/*@}*/
+
+
+/**
+* Two phase constructor
+*/
+CT_DataMeasureTextOutput* CT_DataMeasureTextOutput::NewL()
+	{
+	CT_DataMeasureTextOutput* ret = new (ELeave) CT_DataMeasureTextOutput();
+	CleanupStack::PushL(ret);
+	ret->ConstructL();
+	CleanupStack::Pop(ret);
+	return ret;
+	}
+
+
+/**
+* Protected constructor. First phase construction
+*/
+CT_DataMeasureTextOutput::CT_DataMeasureTextOutput()
+:	CDataWrapperBase()
+,	iMeasureTextOutput(NULL)
+	{
+	}
+
+
+/**
+* Protected second phase construction
+*/
+void CT_DataMeasureTextOutput::ConstructL()
+	{
+	}
+
+
+/**
+* Destructor.
+*/
+CT_DataMeasureTextOutput::~CT_DataMeasureTextOutput()
+	{
+	DestroyData();
+	}
+
+
+/**
+* cleanup implementation.
+*/
+void CT_DataMeasureTextOutput::DestroyData()
+	{
+	delete iMeasureTextOutput;
+	iMeasureTextOutput = NULL;
+	}
+
+
+/**
+* Return a pointer to the object that the data wraps
+*
+* @return pointer to the object that the data wraps
+*/
+TAny* CT_DataMeasureTextOutput::GetObject()
+	{
+	return iMeasureTextOutput;
+	}
+
+
+/**
+* Process a command read from the ini file
+*
+* @param aDataWrapper	test step requiring command to be processed
+* @param aCommand	the command to process
+* @param aSection		the entry in the ini file requiring the command to be processed
+*
+* @return ETrue if the command is processed
+*/
+TBool CT_DataMeasureTextOutput::DoCommandL(const TTEFFunction& aCommand, const TTEFSectionName& aSection, const TInt /*aAsyncErrorIndex*/)
+	{
+	TBool retVal = ETrue;
+
+	if (aCommand == KCmdNew)
+		{
+		DoCmdNew();
+		}
+	else if (aCommand == KCmdSetBounds)
+		{
+		DoCmdSetBounds(aSection);
+		}
+	else if (aCommand == KCmdSetChars)
+		{
+		DoCmdSetChars(aSection);
+		}
+	else if (aCommand == KCmdSetGlyphs)
+		{
+		DoCmdSetGlyphs(aSection);
+		}
+	else if (aCommand == KCmdSetGroups)
+		{
+		DoCmdSetGroups(aSection);
+		}
+	else if (aCommand == KCmdSetMaxGlyphSize)
+		{
+		DoCmdSetMaxGlyphSize(aSection);
+		}
+	else if (aCommand == KCmdSetSpaces)
+		{
+		DoCmdSetSpaces(aSection);
+		}
+	else if (aCommand == KCmdDestructor)
+		{
+		DestroyData();
+		}
+	else
+		{
+		retVal=EFalse;
+		}
+
+	return retVal;
+	}
+
+
+////////////////// COMMANDS IMPLEMENTATION  ////////////////////////
+
+/** Creates an instance of TMeasureTextOutput structure */
+void CT_DataMeasureTextOutput::DoCmdNew()
+	{
+	INFO_PRINTF1(_L("Creates an instance of TMeasureTextOutput structure"));
+
+	// cleanup if any
+	DestroyData();
+
+	// call new operator
+	TRAPD(err, iMeasureTextOutput = new (ELeave) CFont::TMeasureTextOutput());
+
+	// check error code
+	if (err != KErrNone)
+		{
+		ERR_PRINTF2(_L("Error creating an instance: %d"), err);
+		SetError(err);
+		}
+	}
+
+
+/** Sets TMeasureTextOutputData::iChars */
+void CT_DataMeasureTextOutput::DoCmdSetChars(const TDesC& aSection)
+	{
+	INFO_PRINTF1(_L("Sets TMeasureTextOutputData::iChars"));
+
+	// get value from parameters
+	TInt	value;
+	if (GetValueFromConfig(*this,aSection, value))
+		{
+		iMeasureTextOutput->iChars = value;
+		}
+	}
+
+
+/** Sets TMeasureTextOutputData::iGlyphs */
+void CT_DataMeasureTextOutput::DoCmdSetGlyphs(const TDesC& aSection)
+	{
+	INFO_PRINTF1(_L("Sets TMeasureTextOutputData::iGlyphs"));
+
+	// get value from parameters
+	TInt	value;
+	if (GetValueFromConfig(*this, aSection, value))
+		{
+		iMeasureTextOutput->iGlyphs = value;
+		}
+	}
+
+
+/** Sets TMeasureTextOutputData::iGroups */
+void CT_DataMeasureTextOutput::DoCmdSetGroups(const TDesC& aSection)
+	{
+	INFO_PRINTF1(_L("Sets TMeasureTextOutputData::iGroups"));
+
+	// get value from parameters
+	TInt	value;
+	if (GetValueFromConfig(*this, aSection, value))
+		{
+		iMeasureTextOutput->iGroups = value;
+		}
+	}
+
+
+/** Sets TMeasureTextOutputData::iSpaces */
+void CT_DataMeasureTextOutput::DoCmdSetSpaces(const TDesC& aSection)
+	{
+	INFO_PRINTF1(_L("Sets TMeasureTextOutputData::iSpaces"));
+
+	// get value from parameters
+	TInt	value;
+	if (GetValueFromConfig(*this,  aSection, value))
+		{
+		iMeasureTextOutput->iSpaces = value;
+		}
+	}
+
+
+/** Sets TMeasureTextOutputData::iBounds */
+void CT_DataMeasureTextOutput::DoCmdSetBounds(const TDesC& aSection)
+	{
+	INFO_PRINTF1(_L("Sets TMeasureTextOutputData::iBounds"));
+
+	TBool	dataOk = ETrue;
+
+	// get rect Ax from parameters
+	TInt	rectAx;
+	if(!GetIntFromConfig(aSection, KRectAx(), rectAx))
+		{
+		ERR_PRINTF2(_L("No %S"), &KRectAx());
+		SetBlockResult(EFail);
+		dataOk = EFalse;
+		}
+
+	// get rect Ay from parameters
+	TInt	rectAy;
+	if(!GetIntFromConfig(aSection, KRectAy(), rectAy))
+		{
+		ERR_PRINTF2(_L("No %S"), &KRectAy());
+		SetBlockResult(EFail);
+		dataOk = EFalse;
+		}
+
+	// get rect Bx from parameters
+	TInt	rectBx;
+	if(!GetIntFromConfig(aSection, KRectBx(), rectBx))
+		{
+		ERR_PRINTF2(_L("No %S"), &KRectBx());
+		SetBlockResult(EFail);
+		dataOk = EFalse;
+		}
+	
+	// get rect By from parameters
+	TInt	rectBy;
+	if(!GetIntFromConfig(aSection, KRectBy(), rectBy))
+		{
+		ERR_PRINTF2(_L("No %S"), &KRectBy());
+		SetBlockResult(EFail);
+		dataOk = EFalse;
+		}
+
+	// set the field
+	if (dataOk)
+		{
+		iMeasureTextOutput->iBounds.SetRect(rectAx, rectAy, rectBx, rectBy);
+		}
+	}
+
+
+/** Sets TMeasureTextOutputData::iMaxGlyphSize */
+void CT_DataMeasureTextOutput::DoCmdSetMaxGlyphSize(const TDesC& aSection)
+	{
+	INFO_PRINTF1(_L("Sets TMeasureTextOutputData::iMaxGlyphSize"));
+
+	TBool	dataOk = ETrue;
+
+	// get width from parameters
+	TInt	width;
+	if(!GetIntFromConfig(aSection, KWidth(), width))
+		{
+		ERR_PRINTF2(_L("No %S"), &KWidth());
+		SetBlockResult(EFail);
+		dataOk = EFalse;
+		}
+	
+	// get height from parameters
+	TInt	height; 
+	if(!GetIntFromConfig(aSection, KHeight(), height))
+		{
+		ERR_PRINTF2(_L("No %S"), &KHeight());
+		SetBlockResult(EFail);
+		dataOk = EFalse;
+		}
+
+	// set the field
+	if (dataOk)
+		{
+		iMeasureTextOutput->iMaxGlyphSize.iWidth = width;
+		iMeasureTextOutput->iMaxGlyphSize.iHeight = height;
+		}
+	}
+
+
+
+///////////////////////////////// UTIL METHODS //////////////////////////////////////
+
+
+/**
+* Utility method that fetches a int value from parameters
+*/
+TBool CT_DataMeasureTextOutput::GetValueFromConfig(CDataWrapper& iInputStep, const TDesC& aSection, TInt& aValue)
+	{
+	TBool	ret=iInputStep.GetIntFromConfig(aSection, KValue(), aValue);
+	if (!ret)
+		{
+		iInputStep.ERR_PRINTF2(_L("No %S"), &KValue());
+		iInputStep.SetBlockResult(EFail);
+		}
+
+	return ret;
+	}