diff -r 000000000000 -r ba25891c3a9e installationservices/switestfw/test/rtautils/rtautilsserver.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/installationservices/switestfw/test/rtautils/rtautilsserver.cpp Thu Dec 17 08:51:10 2009 +0200 @@ -0,0 +1,105 @@ +/* +* Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of the License "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 "rtautilsserver.h" +#include "rtautilsstep.h" +#include "archivestep.h" +#include "rightsDbStep.h" + +_LIT(KServerName,"aprrtautils"); + +CRTAUtilsServer* CRTAUtilsServer::NewL() + { + CRTAUtilsServer * server = new (ELeave) CRTAUtilsServer(); + CleanupStack::PushL(server); + User::LeaveIfError(server->iFs.Connect()); + + // Make the file session sharable + User::LeaveIfError(server->iFs.ShareProtected()); + + // CServer base class call + server->StartL(KServerName); + CleanupStack::Pop(server); + return server; + } + +// EKA2 much simpler +// Just an E32Main and a MainL() +LOCAL_C void MainL() +/* + * 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().SecureApi(RProcess::ESecureApiOn); +#endif + CActiveScheduler* sched=NULL; + sched=new(ELeave) CActiveScheduler; + CActiveScheduler::Install(sched); + // __EDIT_ME__ Your server name + CRTAUtilsServer* server = NULL; + // Create the CTestServer derived server + // __EDIT_ME__ Your server name + TRAPD(err,server = CRTAUtilsServer::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 error code on exit + */ + { + CTrapCleanup* cleanup = CTrapCleanup::New(); + if(cleanup == NULL) + { + return KErrNoMemory; + } + TRAP_IGNORE(MainL()); + delete cleanup; + return KErrNone; + } + +// Create a thread in the calling process +// Emulator typhoon and earlier + +CTestStep* CRTAUtilsServer::CreateTestStep(const TDesC& aStepName) +/* + * return a CTestStep derived instance + * Implementation of CTestServer pure virtual + */ + { + CTestStep* testStep = NULL; + // They are created "just in time" when the worker thread is created + if(aStepName == KCreateDrmArchive) + testStep = new CCreateDrmArchive(*this); + else if(aStepName == KImportDrmArchive) + testStep = new CImportDrmArchive(*this); + else if(aStepName == KClearRightsDb) + testStep = new CClearRightsDb(*this); + + return testStep; + }