diff -r bbd31066657e -r 8bb370ba6d1d testexecfw/stf/stfext/testmodules/teftestmod/testexecmdw/filelogger/te_rfilelogger/src/te_rfileloggersuiteserver.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/testexecfw/stf/stfext/testmodules/teftestmod/testexecmdw/filelogger/te_rfilelogger/src/te_rfileloggersuiteserver.cpp Fri Apr 09 10:46:28 2010 +0800 @@ -0,0 +1,119 @@ +/* +* 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: +* for (WINS && !EKA2) versions will be xxxServer.Dll and require a thread to be started +* in the process of the client. The client initialises the server by calling the +* one and only ordinal. +* +*/ + + + +/** + @file Te_RFileLoggerSuiteServer.cpp +*/ + +#include "te_rfileloggersuiteserver.h" +#include "addfield_logstep.h" +#include "conn_closestep.h" + +_LIT(KServerName,"Te_RFileLoggerSuite"); +CTe_RFileLoggerSuite* CTe_RFileLoggerSuite::NewL() +/** + * @return - Instance of the test server + * Same code for Secure and non-secure variants + * Called inside the MainL() function to create and start the + * CTestServer derived server. + */ + { + CTe_RFileLoggerSuite * server = new (ELeave) CTe_RFileLoggerSuite(); + CleanupStack::PushL(server); + // CServer base class call which can be either StartL or ConstructL, + // the later will permit Server Logging. + + server->StartL(KServerName); + //server->ConstructL(KServerName); + CleanupStack::Pop(server); + return server; + } + + +// Secure variants much simpler +// For EKA2, just an E32Main and a MainL() +LOCAL_C void MainL() +/** + * Secure variant + * Much simpler, uses the new Rendezvous() call to sync with the client + */ + { + // Leave the hooks in for platform security +#if (defined __DATA_CAGING__) + RProcess().DataCaging(RProcess::EDataCagingOn); + RProcess().DataCaging(RProcess::ESecureApiOn); +#endif + CActiveScheduler* sched=NULL; + sched=new(ELeave) CActiveScheduler; + CActiveScheduler::Install(sched); + CTe_RFileLoggerSuite* server = NULL; + // Create the CTestServer derived server + TRAPD(err,server = CTe_RFileLoggerSuite::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() +/** + * @return - Standard Epoc error code on process exit + * Secure variant only + * Process entry point. Called by client using RProcess API + */ + { + __UHEAP_MARK; + CTrapCleanup* cleanup = CTrapCleanup::New(); + if(cleanup == NULL) + { + return KErrNoMemory; + } + TRAPD(err,MainL()); + delete cleanup; + __UHEAP_MARKEND; + return KErrNone; + } + + +CTestStep* CTe_RFileLoggerSuite::CreateTestStep(const TDesC& aStepName) +/** + * @return - A CTestStep derived instance + * Secure and non-secure variants + * Implementation of CTestServer pure virtual + */ + { + CTestStep* testStep = NULL; + // They are created "just in time" when the worker thread is created + // More test steps can be added below + if(aStepName == Kaddfield_logStep) + testStep = new Caddfield_logStep(); + else if(aStepName == Kconn_closeStep) + testStep = new Cconn_closeStep(); + + return testStep; + }