jrt_plat/java_debug_api/inc/javadebugapi.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 21 Jun 2010 15:32:50 +0300
branchRCL_3
changeset 21 4376525cdefb
parent 12 a9812d2cae03
permissions -rw-r--r--
Revision: v2.1.30 Kit: 2010125

/*
* 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: Java Debug API
*
*/


#ifndef JAVADEBUGAPI_H
#define JAVADEBUGAPI_H

#include <e32cmn.h>
#include <e32std.h>

/**
 * Java Debug API allows it's users to install, remove, start and
 * stop Java applications.
 *
 * @lib javadebugapi.lib
 * @since S60 v9.2
 */

namespace java
{
namespace debug
{

/**
 * Installs Java application.
 * Java application is installed silently i.e. no prompts are shown to the user.
 * @param[in] aFilename shall point to local JAD or JAR file
 * @param[out] aSuiteUid returns the suite uid assigned to the application
 * @param[out] aApplicationUid returns a list of application uids assigned to applications inside suite uid
 * @capability TrustedUI
 * @return true if installation is successful
 */
IMPORT_C TBool installApp(HBufC& aFilename, TUid& aSuiteUid, RArray<TUid>& aApplicationUid);

/**
 * Uninstalls Java application.
 * Java application is removed silently i.e. no prompts are shown to the user.
 * If application uid is given then the application suite it belongs is removed too.
 * @param[in] aUid application suite uid (or application uid)
 * @capability TrustedUI
 * @return true if application is uninstalled successfully
 */
IMPORT_C TBool uninstallApp(TUid aSuiteUid);

/**
 * Starts Java application.
 * @param[in] aApplicationUid application uid
 * @param[in] aUeiParameters includes arguments defined in Unified Emulator Interface (UEI) specification.
 * @param[out] aProcessId process id of the launched Java application, valid if application is launched successfully
 * If aUeiParameters contains unsupported options then those options are discarded silently.
 * Supported arguments:
 *   -Xverbose[:options]
 *   -Xdebug -Xrunjdwp:name=value[,name=value[...]]
 * For example, to start Java application in debug mode and set full tracing on
 * following UIE arguments could be given:
 * "-Xdebug -Xrunjdwp:server=y,address=localhost:8000 -Xverbose:all"
 * @capability NetworkControl
 * @return true if application is started
 */
IMPORT_C TBool startApp(TUid aApplicationUid, HBufC& aUeiParameters, TProcessId& aProcessId);

/**
 * Stops Java application.
 * @param[in] aApplicationUid application uid
 * @capability PowerMgmt
 * @return true if application is stopped
 */
IMPORT_C TBool stopApp(TUid aApplicationUid);

} // end namespace debug
} // end namespace java

#endif // JAVADEBUGAPI_H