dependencies/extended_skin_api/AknsPkgID.h
author MattD <mattd@symbian.org>
Thu, 01 Apr 2010 14:59:15 +0100
branchv5backport
changeset 50 d717d18a59d5
parent 34 1494d39c2fee
permissions -rw-r--r--
Made a minor error with all the messing around with aknlayout.lag which meant it got performed on the default branch.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
34
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     1
/*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     2
* Copyright (c) 2003 Nokia Corporation and/or its subsidiary(-ies).
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     3
* All rights reserved.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     4
* This component and the accompanying materials are made available
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     6
* which accompanies this distribution, and is available
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     8
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
     9
* Initial Contributors:
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    11
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    12
* Contributors:
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    13
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    14
* Description:  Defines the package ID class used to identify skin packages
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    15
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    16
*/
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    17
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    18
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    19
#ifndef AKNSPKGID_H
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    20
#define AKNSPKGID_H
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    21
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    22
//  INCLUDES
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    23
#include <e32std.h>
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    24
#include <e32base.h>
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    25
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    26
// CONSTANTS
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    27
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    28
static const TInt KAknsPkgIDDesSize = 23;
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    29
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    30
// DATA TYPES
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    31
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    32
typedef TBuf<KAknsPkgIDDesSize> TAknsPkgIDBuf;
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    33
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    34
// FORWARD DECLARATIONS
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    35
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    36
// CLASS DECLARATION
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    37
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    38
/**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    39
* Package identifier used to identify skin packages. Package ID may be either
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    40
* a UID or a timestamp and random number pair.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    41
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    42
* Note that the class does not define any constructors. This ensures that 
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    43
* @c TAknsPkgID can be used in ROM constants.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    44
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    45
* @lib AknSkinSrv.lib
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    46
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    47
* @since 2.0
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    48
*/
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    49
class TAknsPkgID
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    50
    {    
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    51
    public: // New functions
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    52
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    53
        /**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    54
        * Sets skin package ID by giving a UID.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    55
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    56
        * @param aUid New UID to be set as the value of the package ID.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    57
        */
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    58
        inline void Set( const TUid aUid );
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    59
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    60
        /**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    61
        * Sets skin package ID by giving a timestamp and a random number.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    62
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    63
        * @param aTimestamp Timestamp as an integer. Must be non-zero.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    64
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    65
        * @param aNumber Random number.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    66
        */
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    67
        inline void Set( const TInt aTimestamp, const TInt aNumber );
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    68
        
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    69
        /**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    70
        * Sets skin package ID by an existing package ID.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    71
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    72
        * @param aID Skin package ID.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    73
        */
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    74
        inline void Set( const TAknsPkgID& aID );
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    75
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    76
        /**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    77
        * Checks whether the skin package ID is a UID.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    78
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    79
        * @return ETrue if the skin package ID is a UID, EFalse otherwise.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    80
        */
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    81
        inline TBool IsUid() const;
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    82
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    83
        /**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    84
        * Returns the skin package ID as a UID. If the package ID is not a
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    85
        * UID, the result is undefined.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    86
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    87
        * @return Skin packge ID as a UID.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    88
        */
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    89
        inline TUid Uid() const;
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    90
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    91
    public: // New functions - String conversions
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    92
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    93
        /**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    94
        * Copies the content of the package ID to the given descriptor.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    95
        * The size of the descriptor must be at least the size of
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    96
        * @c TAknsPkgIDBuf. Otherwise the method may panic.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    97
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    98
        * @param aDes Target descriptor.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
    99
        */
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   100
        IMPORT_C void CopyToDes( TDes& aDes ) const;
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   101
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   102
        /**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   103
        * Sets the content of the package ID based on the given character
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   104
        * representation. The content of the given descriptor must be
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   105
        * valid (as generated by @c CopyToDes). 
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   106
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   107
        * If the given descriptor doesn't contain a correctly formatted
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   108
        * skin package ID the method leaves and the content of the object
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   109
        * is undefined.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   110
        *
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   111
        * @param aDes Source descriptor.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   112
        */
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   113
        IMPORT_C void SetFromDesL( const TDesC& aDes );
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   114
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   115
    public: // Data
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   116
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   117
        TInt iNumber;       //!< Number or UID.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   118
        TInt iTimestamp;    //!< Timestamp (or 0 if UID).
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   119
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   120
    };
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   121
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   122
// CONSTANTS (continued)
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   123
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   124
static const TAknsPkgID KAknsNullPkgID = { 0, 0 };
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   125
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   126
// FUNCTION PROTOTYPES
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   127
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   128
/**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   129
* C++ equal operator.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   130
* Checks whether two package ID objects have identical content.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   131
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   132
* @param aFirst First object to be compared.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   133
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   134
* @param aSecond Second object to be compared.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   135
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   136
* @return true if objects have identical content, false otherwise.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   137
*/
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   138
inline TBool operator==( const TAknsPkgID& aFirst, const TAknsPkgID& aSecond );
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   139
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   140
/**
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   141
* C++ not equal operator.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   142
* Checks whether two package ID objects have identical content.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   143
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   144
* @param aFirst First object to be compared.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   145
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   146
* @param aSecond Second object to be compared.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   147
*
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   148
* @return false if objects have identical content, true otherwise.
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   149
*/
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   150
inline TBool operator!=( const TAknsPkgID& aFirst, const TAknsPkgID& aSecond );
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   151
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   152
// INLINED MEMBERS
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   153
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   154
#include "AknsPkgID.inl"
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   155
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   156
#endif // AKNSITEMID_H   
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   157
1494d39c2fee added few more dependencies
kashif.sayed
parents:
diff changeset
   158
// End of File