javamanager/javaappschemeplugin/src/javaapphandler.cpp
branchRCL_3
changeset 26 2455ef1f5bbc
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/javamanager/javaappschemeplugin/src/javaapphandler.cpp	Wed Sep 01 12:33:18 2010 +0100
@@ -0,0 +1,165 @@
+/*
+* 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:  Implementation of Scheme handler interface implementation
+*      for localapp://jam/launch scheme
+*
+*/
+
+
+// INCLUDE FILES
+#include <e32base.h>
+#include <escapeutils.h>
+#include <apgcli.h>
+#include <eikproc.h>
+#include <apacmdln.h>
+#include <e32const.h>
+#include <flogger.h>
+
+#include "javaapphandler.h"
+
+using namespace java;
+
+namespace java
+{
+
+namespace javaapphandler
+{
+
+// ================= CONSTANTS =======================
+
+_LIT(KJavaLogDir, "java\\full");
+_LIT(KJavaLogFile, "JavaUtils.log");
+
+// ================= MACROS =======================
+
+// Define logging macros here to remove dependencies to Java 2.0 libraries.
+#define LOG(str)  { TBuf8<1024> f((const TUint8 *)str); RFileLogger::Write(KJavaLogDir, KJavaLogFile, EFileLoggingModeAppend, f); }
+#define LOG1(str, a)  { TBuf8<1024> f((const TUint8 *)str); RFileLogger::WriteFormat(KJavaLogDir, KJavaLogFile, EFileLoggingModeAppend, f, a); }
+#define LOG1WSTR(str, wstr) { TBuf8<1024> f((const TUint8 *)str); RFileLogger::Write(KJavaLogDir, KJavaLogFile, EFileLoggingModeAppend, f); TBuf16<KLogBufferSize> w((const TUint16 *)wstr); RFileLogger::Write(KJavaLogDir, KJavaLogFile, EFileLoggingModeAppend, w); }
+
+// ================= MEMBER FUNCTIONS =======================
+
+
+// ---------------------------------------------------------
+// CJavaAppHandler::CJavaAppHandler()
+// ---------------------------------------------------------
+//
+CJavaAppHandler::CJavaAppHandler()
+        : CSchemeHandler()
+{
+}
+
+// ---------------------------------------------------------
+// CJavaAppHandler::ConstructL()
+// ---------------------------------------------------------
+//
+void CJavaAppHandler::ConstructL(const TDesC& aUrl)
+{
+    mParsedUrl = aUrl.AllocL();
+}
+
+// ---------------------------------------------------------
+// CJavaAppHandler::Observer()
+// ---------------------------------------------------------
+//
+
+void CJavaAppHandler::Observer(MAknServerAppExitObserver* /* aSchemeDoc */)
+{
+    // do nothing
+}
+
+// ================= MEMBER FUNCTIONS =======================
+
+// ---------------------------------------------------------
+// CJavaAppHandler::NewL()
+// ---------------------------------------------------------
+//
+CJavaAppHandler* CJavaAppHandler::NewL(const TDesC& aUrl)
+{
+    CJavaAppHandler* self=new(ELeave) CJavaAppHandler();
+    CleanupStack::PushL(self);
+    self->ConstructL(aUrl);
+    CleanupStack::Pop(self);
+
+    return self;
+}
+
+// ---------------------------------------------------------
+// CJavaAppHandler::~CJavaAppHandler()
+// ---------------------------------------------------------
+//
+CJavaAppHandler::~CJavaAppHandler()
+{
+    delete mParsedUrl;
+}
+
+// ---------------------------------------------------------
+// CJavaAppHandler::HandleUrlEmbeddedL()
+// ---------------------------------------------------------
+//
+void CJavaAppHandler::HandleUrlEmbeddedL()
+{
+    HandleUrlStandaloneL();
+}
+
+// ---------------------------------------------------------
+// CJavaAppHandler::HandleUrlStandaloneL()
+// ---------------------------------------------------------
+//
+void CJavaAppHandler::HandleUrlStandaloneL()
+{
+
+
+    // Start javalauncher.exe and pass the Url to it
+    _LIT(KJavaLauncherExe, "javalauncher.exe");
+    RProcess rProcess;
+
+    // start
+    TInt err = rProcess.Create(KJavaLauncherExe, *mParsedUrl);
+    if (KErrNone == err)
+    {
+        // This call will wait until javalauncher exits (or panics)
+        TRequestStatus status;
+        rProcess.Logon(status);
+        rProcess.Resume();
+
+        // now wait until javalauncher exits
+        User::WaitForRequest(status);
+        err = status.Int();
+        if (err != KErrNone)
+        {
+            LOG1("javaapphandler: javalauncher exited with error %d", err);
+        }
+    }
+    else
+    {
+        LOG1("javaapphandler: Cannot create javalauncher process, error %d", err);
+    }
+
+    // free resources before returning
+    rProcess.Close();
+
+    if (KErrNone != err)
+    {
+#ifndef _DEBUG
+        // Make sure Url is logged always if an error has happened
+        TBuf<255> logBuf = mParsedUrl->Left(250);
+        LOG1WSTR("javaapphandler: command line starts with : %s", (TUint16 *)(logBuf.PtrZ()));
+#endif
+        User::Leave(err);
+    }
+}
+
+} // namespace javaapphandler
+} // namespace java