emailservices/emailclientapi/inc/emailmailboxcache.h
author hgs
Mon, 23 Aug 2010 23:32:31 +0300
changeset 62 a8c646b56683
parent 47 f83bd4ae1fe3
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
47
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: Definition for mailbox cache
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef EMAILMAILBOXCACHE_H
hgs
parents:
diff changeset
    19
#define EMAILMAILBOXCACHE_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <e32base.h> 
hgs
parents:
diff changeset
    22
#include <emailapidefs.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
using namespace EmailInterface;
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
class CPluginData;
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
/**
hgs
parents:
diff changeset
    30
* Cache associating mailbox with a protocol plugin. Improves performance by
hgs
parents:
diff changeset
    31
* removing need to load protocol plugins every time a mailbox needs to be
hgs
parents:
diff changeset
    32
* accessed (and keeping plugin loaded when it is not needed)
hgs
parents:
diff changeset
    33
* @since s60 v5.2
hgs
parents:
diff changeset
    34
*/
hgs
parents:
diff changeset
    35
NONSHARABLE_CLASS( CEmailMailboxCache ) : public CBase
hgs
parents:
diff changeset
    36
{
hgs
parents:
diff changeset
    37
public:
hgs
parents:
diff changeset
    38
    /**
hgs
parents:
diff changeset
    39
    * Cache entry to access plugin by mailbox id
hgs
parents:
diff changeset
    40
    */
hgs
parents:
diff changeset
    41
    class TCacheEntry
hgs
parents:
diff changeset
    42
    {
hgs
parents:
diff changeset
    43
    public:
hgs
parents:
diff changeset
    44
        inline TCacheEntry( 
hgs
parents:
diff changeset
    45
            CPluginData* aPluginData, 
hgs
parents:
diff changeset
    46
            TMailboxId aId ) : 
hgs
parents:
diff changeset
    47
            iPluginData( aPluginData ), 
hgs
parents:
diff changeset
    48
            iMailboxId( aId ) {}
hgs
parents:
diff changeset
    49
        CPluginData* iPluginData;
hgs
parents:
diff changeset
    50
        TMailboxId iMailboxId;
hgs
parents:
diff changeset
    51
    };
hgs
parents:
diff changeset
    52
    
hgs
parents:
diff changeset
    53
    /**
hgs
parents:
diff changeset
    54
    * Constructor
hgs
parents:
diff changeset
    55
    */
hgs
parents:
diff changeset
    56
    static CEmailMailboxCache* NewL();
hgs
parents:
diff changeset
    57
    
hgs
parents:
diff changeset
    58
    /** destructor */
hgs
parents:
diff changeset
    59
    ~CEmailMailboxCache();
hgs
parents:
diff changeset
    60
    
hgs
parents:
diff changeset
    61
    /**
hgs
parents:
diff changeset
    62
    * Clears cache and indicates that one or more AddMailboxL calls will 
hgs
parents:
diff changeset
    63
    * follow.
hgs
parents:
diff changeset
    64
    * Cleanup support invalidates cache if leave occurs before EndCachingPop()
hgs
parents:
diff changeset
    65
    * is called
hgs
parents:
diff changeset
    66
    */
hgs
parents:
diff changeset
    67
    void StartCachingPushL();
hgs
parents:
diff changeset
    68
    
hgs
parents:
diff changeset
    69
    /**
hgs
parents:
diff changeset
    70
    * Marks caching fully complete for all mailboxes (call when no more
hgs
parents:
diff changeset
    71
    * AddMailboxL will follow) and pops cleanup item.
hgs
parents:
diff changeset
    72
    */
hgs
parents:
diff changeset
    73
    void EndCachingPop();      
hgs
parents:
diff changeset
    74
    
hgs
parents:
diff changeset
    75
    /**
hgs
parents:
diff changeset
    76
    * Returns if mailboxes are cached
hgs
parents:
diff changeset
    77
    */
hgs
parents:
diff changeset
    78
    TBool IsCached() const;
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
    /**
hgs
parents:
diff changeset
    81
    * Adds mailbox to cache.
hgs
parents:
diff changeset
    82
    * @param aPluginData mailbox associated with plugin(data)
hgs
parents:
diff changeset
    83
    * @param aMailboxId mailbox id
hgs
parents:
diff changeset
    84
    * @precondition: StartCaching must have been called. 
hgs
parents:
diff changeset
    85
    */
hgs
parents:
diff changeset
    86
    void AddMailboxL( CPluginData& aPluginData, const TMailboxId& aMailboxId );
hgs
parents:
diff changeset
    87
    
hgs
parents:
diff changeset
    88
    /**
hgs
parents:
diff changeset
    89
    * Returns plugin data by mailbox id
hgs
parents:
diff changeset
    90
    * @param aMailboxId 
hgs
parents:
diff changeset
    91
    * @return plugin data associated with specified mailbox
hgs
parents:
diff changeset
    92
    */
hgs
parents:
diff changeset
    93
    CPluginData* PluginDataL( const TMailboxId& aMailboxId ) const;
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
    /**
hgs
parents:
diff changeset
    96
    * Returns plugin data by plugin id
hgs
parents:
diff changeset
    97
    * @param aPluginId 
hgs
parents:
diff changeset
    98
    * @return plugin data associated with specified plugin
hgs
parents:
diff changeset
    99
    */
hgs
parents:
diff changeset
   100
    CPluginData* PluginDataL( const TUid& aPluginId ) const;
hgs
parents:
diff changeset
   101
    
hgs
parents:
diff changeset
   102
    /**
hgs
parents:
diff changeset
   103
    * Gets all mailbox ids in all protocol plugins
hgs
parents:
diff changeset
   104
    */
hgs
parents:
diff changeset
   105
    void GetIdsL( REmailMailboxIdArray& aIdArray ) const;
hgs
parents:
diff changeset
   106
    
hgs
parents:
diff changeset
   107
private:    
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
    TInt FindById( const TMailboxId& aMailboxId ) const;
hgs
parents:
diff changeset
   110
    TInt FindByPluginIdL( const TUid& aPluginId ) const;    
hgs
parents:
diff changeset
   111
    static TBool Equals( const TCacheEntry& a1, const  TCacheEntry& a2 );
hgs
parents:
diff changeset
   112
    static TBool PluginEquals( const TCacheEntry& a1, const  TCacheEntry& a2 );
hgs
parents:
diff changeset
   113
    
hgs
parents:
diff changeset
   114
    static void CleanupOp( TAny* aAny );
hgs
parents:
diff changeset
   115
    
hgs
parents:
diff changeset
   116
private:
hgs
parents:
diff changeset
   117
    
hgs
parents:
diff changeset
   118
    CEmailMailboxCache();
hgs
parents:
diff changeset
   119
    
hgs
parents:
diff changeset
   120
    void ConstructL();
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
    enum TCacheState {
hgs
parents:
diff changeset
   123
        EEmpty,
hgs
parents:
diff changeset
   124
        ECaching,
hgs
parents:
diff changeset
   125
        EComplete
hgs
parents:
diff changeset
   126
    };
hgs
parents:
diff changeset
   127
private:
hgs
parents:
diff changeset
   128
    // empty, caching or caching complete
hgs
parents:
diff changeset
   129
    TCacheState iState;
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
    // cached mailbox id with associated plugin data
hgs
parents:
diff changeset
   132
    RArray<TCacheEntry> iEntries;
hgs
parents:
diff changeset
   133
};
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
hgs
parents:
diff changeset
   136
#endif // EMAILMAILBOXCACHE_H
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
// End of file