dependencies/javaregistryapplicationentry.h
author MattD <mattd@symbian.org>
Thu, 01 Apr 2010 12:25:43 +0100
branchv5backport
changeset 46 db99fd9fcd1c
parent 31 a3e98f9c292b
permissions -rw-r--r--
Removed all abld.bat and .cproject files as they rpobably shouldn't be committed, and are just going to cause unneccessary merge/build issues

/*
* Copyright (c) 2005-2006 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 Registy API header file
*
*/


#ifndef JAVAREGISTRYAPPLICATIONENTRY_H
#define JAVAREGISTRYAPPLICATIONENTRY_H

#include <e32base.h>
#include <e32cmn.h>
#include <f32file.h>
#include "javaregistryentry.h"
#include "javaregistryentrytype.h"

namespace Java
{
namespace Manager
{
namespace Registry
{

// FORWARD DECLARATION
class CWriteableJavaRegistryApplicationEntry;

}// namespace Registry
}// namespace Manager

// FORWARD DECLARATION
class CJavaRegistryPackageEntry;

/**
 * This subclass of CJavaRegistryEntry supports attributes
 * for single application, that can't contain embedded entries.
 *
 * @lib javaregistryclient.lib
 * @since S60 v3.2
 */
class CJavaRegistryApplicationEntry : public CJavaRegistryEntry
{
public:


    /**
     * CJavaRegistryApplicationEntry::CJavaRegistryApplicationEntry
     * constructor
     *
     * @since S60 v3.2
     * @param aWritableEntry Pointer to a writable entry, to delegate
     *          getter methods. Pointer ownership taken.
     */
    CJavaRegistryApplicationEntry(Java::Manager::Registry::
                                  CWriteableJavaRegistryApplicationEntry* aWritableEntry);

    /**
     * Tells if this application is startable.
     *
     * @since S60 v3.2
     * @return ETrue if the application is startable, EFalse otherwise.
     *         Default value if not set: ETrue.
     */
    IMPORT_C TBool IsStartable() const;

    /**
     * Tells if this application must be shown in Application Shell or
     * it must rather be hidden.
     *
     * @since S60 v3.2
     * @return ETrue if the application is shown in Application Shell,
     *         EFalse otherwise.
     *         Default value if not set: ETrue.
     */
    IMPORT_C TBool IsVisible() const;

    /**
     * Tells if the end user can not uninstall this application.
     *
     * @since S60 v3.2
     * @return ETrue if the application is resident, EFalse otherwise.
     *         Default value if not set: EFalse.
     */
    IMPORT_C TBool IsResident() const;

    /**
     * Gets the group name of this application. This property tells in
     * which folder the application icon shall appear. It can be a
     * null-string: in that case the Installed folder will be hosting
     * midlet icons.
     *
     * @since S60 v3.2
     * @return Group name of this application.
     *         Default value if not set:
     */
    IMPORT_C const TDesC& GroupName() const;

    /**
     * Gets a reference to the install package entry, which is the parent
     * of this application. E.g. if this entry represents a MIDlet this
     * method returns a reference to the corresponding MIDlet Suite entry.
     * The function may leave with one of the system-wide error codes.
     *
     * @since S60 v3.2
     * @return a CJavaRegistryEntry object. Caller takes over the
     *         ownership of the object being transferred.
     */
    IMPORT_C CJavaRegistryPackageEntry* PackageEntryL() const;

protected:

    /**
     * CJavaRegistryApplicationEntry::WritableEntry method returns the member
     * of the parent class, but first casts it to
     * CWriteableJavaRegistryApplicationEntry.
     *
     * @since S60 v3.2
     * @return Returns the member of this class.
     */
    Java::Manager::Registry::
    CWriteableJavaRegistryApplicationEntry* WritableEntry() const;

};

} // namespace Java

#endif // JAVAREGISTRYAPPLICATIONENTRY_H