sl@0: // Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies). sl@0: // All rights reserved. sl@0: // This component and the accompanying materials are made available sl@0: // under the terms of "Eclipse Public License v1.0" sl@0: // which accompanies this distribution, and is available sl@0: // at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: // sl@0: // Initial Contributors: sl@0: // Nokia Corporation - initial contribution. sl@0: // sl@0: // Contributors: sl@0: // sl@0: // Description: sl@0: // for (WINS && !EKA2) versions will be xxxServer.Dll and require a thread to be started sl@0: // in the process of the client. The client initialises the server by calling the sl@0: // one and only ordinal. sl@0: // sl@0: // sl@0: sl@0: #include "Te_floating_scheduleSuiteServer.h" sl@0: #include "persist_hometimeStep.h" sl@0: #include "persist_utcStep.h" sl@0: #include "persist_mixedStep.h" sl@0: #include "persist_hometime_floatStep.h" sl@0: #include "transient_hometimeStep.h" sl@0: #include "transient_utcStep.h" sl@0: #include "transient_mixedStep.h" sl@0: #include "transient_hometime_floatStep.h" sl@0: #include "hometime_floatStep.h" sl@0: #include "DEF061595_Step.h" sl@0: sl@0: _LIT(KServerName,"Te_floating_scheduleSuite"); sl@0: CTe_floating_scheduleSuite* CTe_floating_scheduleSuite::NewL() sl@0: /** sl@0: * @return - Instance of the test server sl@0: * Same code for Secure and non-secure variants sl@0: * Called inside the MainL() function to create and start the sl@0: * CTestServer derived server. sl@0: */ sl@0: { sl@0: CTe_floating_scheduleSuite * server = new (ELeave) CTe_floating_scheduleSuite(); sl@0: CleanupStack::PushL(server); sl@0: // CServer base class call which can be either StartL or ConstructL, sl@0: // the later will permit Server Logging. sl@0: sl@0: server->StartL(KServerName); sl@0: //server->ConstructL(KServerName); sl@0: CleanupStack::Pop(server); sl@0: return server; sl@0: } sl@0: sl@0: sl@0: // Secure variants much simpler sl@0: // For EKA2, just an E32Main and a MainL() sl@0: LOCAL_C void MainL() sl@0: /** sl@0: * Secure variant sl@0: * Much simpler, uses the new Rendezvous() call to sync with the client sl@0: */ sl@0: { sl@0: // Leave the hooks in for platform security sl@0: #if (defined __DATA_CAGING__) sl@0: RProcess().DataCaging(RProcess::EDataCagingOn); sl@0: RProcess().DataCaging(RProcess::ESecureApiOn); sl@0: #endif sl@0: CActiveScheduler* sched=NULL; sl@0: sched=new(ELeave) CActiveScheduler; sl@0: CActiveScheduler::Install(sched); sl@0: CTe_floating_scheduleSuite* server = NULL; sl@0: // Create the CTestServer derived server sl@0: TRAPD(err,server = CTe_floating_scheduleSuite::NewL()); sl@0: if(!err) sl@0: { sl@0: // Sync with the client and enter the active scheduler sl@0: RProcess::Rendezvous(KErrNone); sl@0: sched->Start(); sl@0: } sl@0: delete server; sl@0: delete sched; sl@0: } sl@0: sl@0: sl@0: sl@0: GLDEF_C TInt E32Main() sl@0: /** sl@0: * @return - Standard Epoc error code on process exit sl@0: * Secure variant only sl@0: * Process entry point. Called by client using RProcess API sl@0: */ sl@0: { sl@0: __UHEAP_MARK; sl@0: CTrapCleanup* cleanup = CTrapCleanup::New(); sl@0: if(cleanup == NULL) sl@0: { sl@0: return KErrNoMemory; sl@0: } sl@0: TRAPD(err,MainL()); sl@0: delete cleanup; sl@0: __UHEAP_MARKEND; sl@0: return err; sl@0: } sl@0: sl@0: sl@0: CTestStep* CTe_floating_scheduleSuite::CreateTestStep(const TDesC& aStepName) sl@0: /** sl@0: * @return - A CTestStep derived instance sl@0: * Secure and non-secure variants sl@0: * Implementation of CTestServer pure virtual sl@0: */ sl@0: { sl@0: CTestStep* testStep = NULL; sl@0: // They are created "just in time" when the worker thread is created sl@0: // More test steps can be added below sl@0: if(aStepName == Kpersist_hometimeStep) sl@0: testStep = new Cpersist_hometimeStep(); sl@0: else if(aStepName == Kpersist_utcStep) sl@0: testStep = new Cpersist_utcStep(); sl@0: else if(aStepName == Kpersist_mixedStep) sl@0: testStep = new Cpersist_mixedStep(); sl@0: else if(aStepName == Kpersist_hometime_floatStep) sl@0: testStep = new Cpersist_hometime_floatStep(); sl@0: else if(aStepName == Ktransient_hometimeStep) sl@0: testStep = new Ctransient_hometimeStep(); sl@0: else if(aStepName == Ktransient_utcStep) sl@0: testStep = new Ctransient_utcStep(); sl@0: else if(aStepName == Ktransient_mixedStep) sl@0: testStep = new Ctransient_mixedStep(); sl@0: else if(aStepName == Ktransient_hometime_floatStep) sl@0: testStep = new Ctransient_hometime_floatStep(); sl@0: else if(aStepName == Khometime_floatStep) sl@0: testStep = new Chometime_floatStep(); sl@0: else if(aStepName == KDEF061595_Step) sl@0: testStep = new CDEF061595_Step(); sl@0: sl@0: return testStep; sl@0: }