graphicsdeviceinterface/bitgdi/tbit/TBitgdiServer.cpp
author William Roberts <williamr@symbian.org>
Tue, 01 Jun 2010 15:04:40 +0100
branchEGL_MERGE
changeset 86 841b49c57c50
parent 0 5d03bc08d59c
child 136 62bb7c97884c
permissions -rw-r--r--
Automatic catchup from NewGraphicsArchitecture at de3e07519bb7

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

/**
 @file
 @test
 @internalComponent - Internal Symbian test code 
*/

#include "TBitgdiServer.h"
#include "TAUTO.H"
#include "tbase.h"
#include "TClip.h"
#include "tparam.h"
#include "tswitch.h"
#include "TAccelerator.h"
#include "TDefect.h"
#include "TDefect2.h"
#include "tbitblt.h"
#include "TBitgdiScaling.h"
#include "TAlphaBlend.h"
#include "tfontselect.h"
#include "TFont.h"
#include "toutlineandshadowfonts.h"
#include "textendedbitmap.h"

 

_LIT(KServerName,"TBitgdiServer");

CTBitgdiServer* CTBitgdiServer::NewL()
	{
	CTBitgdiServer * server = new (ELeave) CTBitgdiServer();
	CleanupStack::PushL(server);
	// CServer base class call
	server->StartL(KServerName);
	CleanupStack::Pop(server);
	return server;
	}


LOCAL_C void MainL()
	{
 	RProcess().DataCaging(RProcess::EDataCagingOn);
	RProcess().SecureApi(RProcess::ESecureApiOn);
	CActiveScheduler* sched=NULL;
	sched=new(ELeave) CActiveScheduler;
	CActiveScheduler::Install(sched);
	CTBitgdiServer* server = NULL;
	// Create the CTestServer derived server
	TRAPD(err,server = CTBitgdiServer::NewL());
	if(!err)
		{
		// Sync with the client and enter the active scheduler
		RProcess::Rendezvous(KErrNone);
		sched->Start();
		}
	delete server;
	delete sched;
	}

GLDEF_C TInt E32Main()
	{
	__UHEAP_MARK;
	CTrapCleanup* cleanup = CTrapCleanup::New();
	if(cleanup == NULL)
		{
		return KErrNoMemory;
		}
	TRAPD(err,MainL());
	if (err)
	    {
		RDebug::Print(_L("TBitgdiServer::MainL - Error: %d"), err);
	   	User::Panic(KServerName,err);
	    }
	delete cleanup;
	__UHEAP_MARKEND;
	return KErrNone;
    }



CTestStep* CTBitgdiServer::CreateTestStep(const TDesC& aStepName)
	{
	CTestStep* testStep = NULL;
	
	if(aStepName == KTAutoStep)
		{
		testStep = new CTAutoStep();
		}
	else if(aStepName == KTGdiStep)
		{
		testStep = new CTGdiStep();
		}
	else if(aStepName == KTClipStep)
		{
		testStep = new CTClipStep();
		}
	else if(aStepName == KTClip2Step)
		{
		testStep = new CTClip2Step();
		}
	else if(aStepName == KTParamStep)
		{
		testStep = new CTParamStep();
		}
	else if(aStepName == KTSwitchStep)
		{
		testStep = new CTSwitchStep();
		}
	else if(aStepName == KTAcceleratorStep)
		{
		testStep = new CTAcceleratorStep();
		}
	else if(aStepName == KTDefectStep)
		{
		testStep = new CTDefectStep();
		}
	else if(aStepName == KTDefect2Step)
		{
		testStep = new CTDefect2Step();
		}
	else if(aStepName == KTBitBltStep)
		{
		testStep = new CTBitBltStep();
		}
	else if(aStepName == KTBitgdiScalingStep)
		{
		testStep = new CTBitgdiScalingStep();
		}
	else if(aStepName == KTAlphaBlendingStep)
		{
		testStep = new CTAlphaBlendingStep();
		}
	else if(aStepName == KTFontSelectStep)
		{
		testStep = new CTFontSelectStep();
		}		
	else if(aStepName == KTFontStep)
		{
		testStep = new CTFontStep();
		}		
	else if(aStepName == KTOutlineAndShadowFontsStep)
		{
		testStep = new CTOutlineAndShadowFontsStep();
		}
	else if(aStepName == KTExtendedBitmapStep)
		{
		testStep = new CTExtendedBitmapStep();
		}
	else if(aStepName == KTExtendedBitmapNegativeStep)
		{
		testStep = new CTExtendedBitmapNegativeStep();
		}
	TBuf<64> log;
	_LIT(KBitgdi,"BITGDI Test %S ");
	_LIT(KSucess,"created sucessfully.");
	_LIT(KFail,"failed to create.");
	log.Format(KBitgdi,&aStepName);
	if (testStep)
		log.Append(KSucess);
	else
		{
		log.Append(KFail);
		INFO_PRINTF1(log);
		}
	RDebug::Print(log);
	return testStep;
	}