javamanager/debugapi/src.s60/diagnosticimpl.cpp
branchRCL_3
changeset 19 04becd199f91
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/javamanager/debugapi/src.s60/diagnosticimpl.cpp	Tue Apr 27 16:30:29 2010 +0300
@@ -0,0 +1,155 @@
+/*
+* 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: DiagnosticImpl provides implementation for JavaDiagnostic
+*
+*/
+
+
+#include "diagnosticimpl.h"
+#include "javaredirectserver.h"
+using namespace java::debug;
+
+_LIT(KJavaRedirectThread,"JavaRedirectServerThread");
+const int REDIRECT_THREAD_STACK_SIZE = 0x5000;
+
+DiagnosticImpl::DiagnosticImpl() : CActive(EPriorityStandard), mListener(0)
+{
+}
+
+DiagnosticImpl::~DiagnosticImpl()
+{
+    stop();
+}
+
+TInt DiagnosticImpl::setDiagnosticListener(DiagnosticListener& aListener)
+{
+    TInt rc = KErrAlreadyExists;
+    if (!mListener)
+    {
+        mListener = &aListener;
+        rc = start();
+        if (rc != KErrNone)
+        {
+            mListener = 0;
+        }
+    }
+    return rc;
+}
+
+void DiagnosticImpl::removeDiagnosticListener()
+{
+    stop();
+    mListener = 0;
+}
+
+TInt DiagnosticImpl::start()
+{
+    TInt rc = mThread.Create(
+                  KJavaRedirectThread,
+                  reinterpret_cast<TThreadFunction>(messageLoop),
+                  REDIRECT_THREAD_STACK_SIZE,
+                  NULL,
+                  this);
+
+    if (rc == KErrNone)
+    {
+        // block until thread has been started ok
+        TRequestStatus rendezvousStatus;
+        mThread.Rendezvous(rendezvousStatus);
+        mThread.Resume();
+        User::WaitForRequest(rendezvousStatus);
+        rc = rendezvousStatus.Int();
+    }
+    return rc;
+}
+
+void DiagnosticImpl::stop()
+{
+    if (mListener)
+    {
+        TRequestStatus status;
+        mThread.Logon(status);
+
+        TRequestStatus* istatus = &iStatus;
+        mThread.RequestComplete(istatus, KErrNone);
+
+        User::WaitForRequest(status);
+        mThread.Close();
+    }
+}
+
+void DiagnosticImpl::messageLoop(TAny* aArgs)
+{
+    CTrapCleanup* cleanup = CTrapCleanup::New();
+    TInt r = KErrNoMemory;
+    if (cleanup)
+    {
+        DiagnosticImpl* me = reinterpret_cast<DiagnosticImpl*>(aArgs);
+        TRAP(r,me->runServerL());
+    }
+
+    RThread::Rendezvous(r);
+    delete cleanup;
+}
+
+void DiagnosticImpl::runServerL()
+{
+    CActiveScheduler* s = new(ELeave) CActiveScheduler;
+    CleanupStack::PushL(s);
+    CActiveScheduler::Install(s);
+
+    java::util::CRedirectServer* server = new(ELeave) java::util::CRedirectServer(*this);
+    CleanupStack::PushL(server);
+
+    server->StartL();
+
+    CActiveScheduler::Add(this);
+    iStatus = KRequestPending;
+    SetActive();
+
+    RThread::Rendezvous(KErrNone);
+    CActiveScheduler::Start();
+
+    CleanupStack::PopAndDestroy(server);
+    CleanupStack::PopAndDestroy(s);
+}
+
+void DiagnosticImpl::RunL()
+{
+    CActiveScheduler::Stop();
+}
+
+void DiagnosticImpl::DoCancel()
+{
+}
+
+TInt DiagnosticImpl::RunError(TInt /*aError*/)
+{
+    return KErrNone;
+}
+
+void DiagnosticImpl::systemOut(const TDesC8& aData)
+{
+    mListener->systemOut(aData);
+}
+
+void DiagnosticImpl::systemErr(const TDesC8& aData)
+{
+    mListener->systemErr(aData);
+}
+
+void DiagnosticImpl::log(const TDesC8& aData)
+{
+    mListener->log(aData);
+}