dependencies/javaregistry.h
author MattD <mattd@symbian.org>
Thu, 01 Apr 2010 12:18:40 +0100
branchv5backport
changeset 45 fd868a928992
parent 31 a3e98f9c292b
permissions -rw-r--r--
Merging in kashif's additional head into fdim's
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
31
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     1
/*
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     2
* Copyright (c) 2005-2006 Nokia Corporation and/or its subsidiary(-ies).
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     3
* All rights reserved.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     4
* This component and the accompanying materials are made available
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     6
* which accompanies this distribution, and is available
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     8
*
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
     9
* Initial Contributors:
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    11
*
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    12
* Contributors:
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    13
*
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    14
* Description:  The main class of Java Registy API. Java Registy API
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    15
*               can be used to query the installed Java applications
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    16
*               and their properties.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    17
*
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    18
*/
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    19
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    20
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    21
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    22
// JAVAREGISTRY.H
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    23
#ifndef JAVAREGISTRY_H
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    24
#define JAVAREGISTRY_H
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    25
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    26
#include <e32base.h>
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    27
#include "javaregistryentrytype.h"
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    28
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    29
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    30
namespace Java
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    31
{
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    32
namespace Manager
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    33
{
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    34
namespace Registry
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    35
{
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    36
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    37
// FORWARD DECLARATION
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    38
class CWriteableJavaRegistry;
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    39
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    40
}// namespace Registry
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    41
}// namespace Manager
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    42
}// namespace Java
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    43
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    44
namespace Java
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    45
{
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    46
class CJavaRegistryEntry;
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    47
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    48
/**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    49
 * This class provides the Platform API for JavaRegistry.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    50
 * It allows for clients to retrieve properties of
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    51
 * Java install packages, applications, services etc.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    52
 *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    53
 * @lib javaregistryclient.lib
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    54
 * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    55
 */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    56
class CJavaRegistry : public CBase
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    57
{
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    58
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    59
    // Constructors
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    60
public:
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    61
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    62
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    63
     * Creates a CJavaRegistry object.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    64
     * The function may leave with one of the system-wide error codes.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    65
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    66
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    67
     * @return A pointer to a CJavaRegistry object.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    68
     *         Caller takes over the ownership of the object being
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    69
     *         transferred.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    70
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    71
    IMPORT_C static CJavaRegistry* NewL();
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    72
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    73
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    74
     * Creates a CJavaRegistry object.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    75
     * The function may leave with one of the system-wide error codes.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    76
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    77
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    78
     * @return A pointer to a CJavaRegistry object.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    79
     *         Caller takes over the ownership of the object being
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    80
     *         transferred.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    81
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    82
    IMPORT_C static CJavaRegistry* NewLC();
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    83
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    84
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    85
public:
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    86
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    87
    // Generic methods
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    88
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    89
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    90
     * Returns whether registry entry with the specified Uid exists.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    91
     * Registry entries representing entities installed on
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    92
     * removable media which are currently not present in the device
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    93
     * are considered as not existent.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    94
     * The function may leave with one of the system-wide error codes.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    95
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    96
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    97
     * @param aUid The Uid to be checked.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    98
     * @return ETrue if the registry entry exists, EFalse otherwise.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
    99
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   100
    IMPORT_C TBool RegistryEntryExistsL(const TUid& aUid) const;
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   101
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   102
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   103
     * Returns an array of Uids of the existing registry entries.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   104
     * Uids of registry entries representing entities installed on
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   105
     * removable media which are currently not present in the device
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   106
     * are not returned.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   107
     * The function may leave with one of the system-wide error codes.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   108
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   109
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   110
     * @param aUids [out] Uids of the registry entries.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   111
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   112
    IMPORT_C void GetRegistryEntryUidsL(RArray<TUid>& aUids) const;
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   113
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   114
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   115
     * Returns an array of Uids of the existing registry entries.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   116
     * Entries are searched by the specified type.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   117
     * Uids of registry entries representing entities installed on
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   118
     * removable media which are currently not present in the device
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   119
     * are not returned.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   120
     * The function may leave with one of the system-wide error codes.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   121
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   122
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   123
     * @param aType Type of registry entries whose Uids are to be returned.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   124
     * @param aUids [out] Uids of the matching registry entries.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   125
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   126
    IMPORT_C void GetRegistryEntryUidsL
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   127
    (TJavaRegistryEntryType aType, RArray<TUid>& aUids) const;
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   128
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   129
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   130
     * Returns the corresponding registry entry for a given Uid.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   131
     * The returned entry can be casted to the appropriate subclass
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   132
     * according to the type property. If type is in the package range
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   133
     * ( EGeneralPackage <= entryType < EGeneralApplication ), it can
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   134
     * be casted to CJavaRegistryPackageEntry, and if type is
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   135
     * in the application range ( EGeneralApplication <= entryType ),
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   136
     * it can be casted to CJavaRegistryApplicationEntry.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   137
     * Registry entries representing entities installed on
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   138
     * removable media which are currently not present in the device
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   139
     * are not returned.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   140
     * The function may leave with one of the system-wide error codes.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   141
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   142
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   143
     * @param aUid The Uid of the entry to be retrieved
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   144
     * @return The returned registry entry or null if registry entry
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   145
     *         not found. Caller takes over the ownership of the object
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   146
     *         being transferred.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   147
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   148
    IMPORT_C CJavaRegistryEntry* RegistryEntryL(const TUid& aUid) const;
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   149
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   150
    // Destructor
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   151
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   152
     * CJavaRegistry::~CJavaRegistry destructor
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   153
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   154
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   155
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   156
    virtual ~CJavaRegistry();
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   157
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   158
private:
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   159
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   160
    // Constructor
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   161
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   162
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   163
     * CJavaRegistry::CJavaRegistry constructor
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   164
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   165
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   166
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   167
    CJavaRegistry();
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   168
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   169
    // 2nd phase constructor
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   170
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   171
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   172
     * CJavaRegistry::ConstructL method
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   173
     * The function may leave with one of the system-wide error codes.
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   174
     *
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   175
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   176
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   177
    void ConstructL();
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   178
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   179
private: // Data
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   180
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   181
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   182
    /**
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   183
     * CJavaRegistry::iJavaReg member
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   184
     * Pointer Owned
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   185
     * @since S60 v3.2
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   186
     */
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   187
    Java::Manager::Registry::CWriteableJavaRegistry* iJavaReg;
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   188
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   189
};
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   190
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   191
}// namespace Java
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   192
a3e98f9c292b added missing files
kashif.sayed
parents:
diff changeset
   193
#endif // JAVAREGISTRY_H