dbgagents/trkagent/toolsstarter/toolsstarterserver/autolaunch/src/toolsstarterautolaunch.cpp
changeset 0 c6b0df440bee
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/dbgagents/trkagent/toolsstarter/toolsstarterserver/autolaunch/src/toolsstarterautolaunch.cpp	Tue Mar 02 10:33:16 2010 +0530
@@ -0,0 +1,239 @@
+/*
+* Copyright (c) 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: 
+*
+*/
+
+// INCLUDE FILES
+#include <apmrec.h>
+#include <ecom/implementationproxy.h>
+#include <e32debug.h>
+#include <startupdomainpskeys.h>
+
+#include "toolsstarterautolaunch.h"
+#include "logging.h"
+
+#define KPSDelay 500000
+
+
+// CONSTANTS
+const static TUint KToolsStarterAutoLaunchImplUid = 0x200170B9;
+const static TUid KToolsStarterAutoLaunchUid = {0x200170B8};
+_LIT(KToolsStarterServerExe, "toolsstarterserver.exe");
+const TUid KToolsStarterServerExeUid = {0x200170B5};
+_LIT( KToolsStarterMatchPattern, "toolsstarterserver**" );
+
+const TImplementationProxy ImplementationTable[] =
+    {
+    IMPLEMENTATION_PROXY_ENTRY( KToolsStarterAutoLaunchImplUid,
+    		CToolsStarterAutoLaunch::CreateRecognizerL )
+    };
+
+
+// ============================ MEMBER FUNCTIONS ===============================
+
+EXPORT_C const TImplementationProxy* ImplementationGroupProxy( TInt& aTableCount )
+    {
+    aTableCount = sizeof(ImplementationTable) / sizeof(TImplementationProxy);
+    return ImplementationTable;
+    }
+
+
+CApaDataRecognizerType* CToolsStarterAutoLaunch::CreateRecognizerL()
+    {
+	LOG_MSG("CToolsStarterAutoLaunch::CreateRecognizerL");
+
+	CApaDataRecognizerType* recognizer = new (ELeave) CToolsStarterAutoLaunch();
+	CToolsStarterAutoLaunch::CreateAutoStartThreadL();
+    return recognizer;
+    }
+
+
+CToolsStarterAutoLaunch::CToolsStarterAutoLaunch() :
+    CApaDataRecognizerType( KToolsStarterAutoLaunchUid, CApaDataRecognizerType::ENormal )
+    {
+    iCountDataTypes = 1;
+    }
+
+
+
+TUint CToolsStarterAutoLaunch::PreferredBufSize()
+    {
+    return 0;
+    }
+
+
+TDataType CToolsStarterAutoLaunch::SupportedDataTypeL( TInt /*aIndex*/ ) const
+    {
+    return TDataType();
+    }
+
+
+void CToolsStarterAutoLaunch::DoRecognizeL( const TDesC& /*aName*/, const TDesC8& /*aBuffer*/ )
+    {
+    }
+
+
+void CToolsStarterAutoLaunch::CreateAutoStartThreadL()
+    {
+    LOG_MSG("CToolsStarterAutoLaunch::CreateAutoStartThread");
+    
+    //create a new thread for starting our application
+    RThread startAppThread;
+
+    User::LeaveIfError( startAppThread.Create(
+        _L( "ToolsStarterAutoLaunch" ),
+        CToolsStarterAutoLaunch::StartAppThreadFunction,
+        KDefaultStackSize,
+        KMinHeapSize,
+        KMinHeapSize,
+        NULL,
+        EOwnerThread ) );
+
+    startAppThread.SetPriority( EPriorityNormal );
+    startAppThread.Resume();
+    startAppThread.Close();
+    }
+
+
+TInt CToolsStarterAutoLaunch::StartAppThreadFunction( TAny* /*aParam*/ )
+    {
+    LOG_MSG("CToolsStarterAutoLaunch::StartAppThreadFunction");
+    
+     // create a trap cleanup and active scheduler
+    CTrapCleanup* pC = CTrapCleanup::New();
+    
+    //CActiveScheduler* pS = new CActiveScheduler;
+    //CActiveScheduler::Install(pS);
+    
+    if (pC==NULL)// || pS==NULL)
+        LOG_MSG("Failed to create the trapcleanup and active scheduler");
+        
+            // create a server starter instance
+    CToolsStarterLauncher* serverStarter = NULL;
+    TRAPD(err, serverStarter = CToolsStarterLauncher::NewL());
+    
+    if (err == KErrNone)
+    	{
+	    // wait for UI to be up
+	   // serverStarter->WaitForUiServices();
+		// now start the toolsstarter server
+		serverStarter->StartServer();
+		delete serverStarter;	    
+	   	}    
+
+  	delete pC;
+  	//delete pS;
+  	
+    return KErrNone;
+    }
+
+
+CToolsStarterLauncher* CToolsStarterLauncher::NewL()
+    {
+    CToolsStarterLauncher* self = new(ELeave) CToolsStarterLauncher();
+    CleanupStack::PushL(self);
+    self->ConstructL();
+    CleanupStack::Pop();
+    return self;
+    }
+
+
+
+CToolsStarterLauncher::CToolsStarterLauncher()
+    {
+    }
+
+
+    
+CToolsStarterLauncher::~CToolsStarterLauncher()
+    {
+
+    }
+
+
+ 
+void CToolsStarterLauncher::ConstructL()
+    {
+    }
+
+void CToolsStarterLauncher::StartServer()
+    {
+    LOG_MSG("CToolsStarterLauncher::StartServer");
+    
+    // check if toolsstarter is already running
+    TFullName processName;
+    TFindProcess finder( KToolsStarterMatchPattern );
+    TInt err = finder.Next( processName );
+    if ( err == KErrNone )
+        {
+        LOG_MSG("KToolsStarterMatchPattern server already running");
+        return;
+        }
+
+    // otherwise create a new process
+    RProcess pr;
+    err = pr.Create(KToolsStarterServerExe, TPtr(NULL, 0), TUidType(KNullUid, KNullUid, KToolsStarterServerExeUid));
+    if ( err == KErrNone )
+        {
+        LOG_MSG("CToolsStarterLauncher::StartServer process created");
+        pr.Resume();
+        pr.Close();
+        }
+    else
+        {
+        LOG_MSG2("CToolsStarterLauncher::StartServer Could not create process %d", err);
+        }
+    }
+
+
+void CToolsStarterLauncher::WaitForUiServices()
+    {
+    LOG_MSG("ToolsStarter Launcher: WaitForUiServices");
+    RProperty property;
+    TInt err = KErrNotReady;
+    while ( err != KErrNone )
+        {
+        User::After(KPSDelay); // Wait for the startup to define the key
+        err = property.Attach(KPSUidStartup, KPSGlobalSystemState);
+        LOG_MSG2("ToolsStarter Launcher: WaitForUiServices attach err %d \n", err);
+        }
+    // Wait for the correct startup state
+    TRequestStatus status;
+    property.Subscribe(status);
+    TInt state = 0;
+    err = property.Get(state);
+    LOG_MSG3("ToolsStarter Launcher: WaitForUiServices state %d err %d \n", state, err);
+    while ( err == KErrNone &&
+            !( state == ESwStateCriticalPhaseOK ||
+               state == ESwStateNormalRfOn ||
+               state == ESwStateNormalRfOff ||
+               state == ESwStateNormalBTSap ) )
+        {
+        state = 0; // Reset previous value
+        User::WaitForRequest(status);
+        err = status.Int();
+        if ( err == KErrNone )
+            {
+            property.Subscribe( status );
+            err = property.Get( state );
+            }
+        LOG_MSG3("ToolsStarter Launcher: WaitForUiServices state changed %d err %d", state, err);
+        }
+    property.Cancel();
+    property.Close();
+    LOG_MSG("ToolsStarter Launcher: WaitForUiServices end");
+    }
+
+