idlehomescreen/inc/xndomstringpool.h
author Christian Morlok <symbian.org@christianmorlok.de>
Wed, 07 Apr 2010 14:39:44 +0200
branchv5backport
changeset 29 968d4f764c35
parent 2 08c6ee43b396
permissions -rw-r--r--
renamed dlls+exe to prevent conflicts with existing files in emulator; changelog attached. * renamed dlls/exe: - aifw.dll to aifw_hs.dll - cputils to cputils_hs - aiidleint.dll to aiidleint_hs.dll - aiutils.dll to aiutils_hs.dll - MenuInterface.dll to MenuInterface_hs.dll - XCFW.dll to XCFW_hs.dll - homescreen.exe to homescreen_hs.exe - ailaunch.exe to ailaunch_hs.exe * new UID for Active Idle (aifw_hs.dll, aiidleint_hs.dll and homescreen.exe): #define AI_UID3_AIFW_COMMON 0xEDFF45C4 (was 0x102750F0 = 271012080) * new UID for cputils_hs.dll: 0xE3E7134E (was 0x20016B7F = 536963967) * new UID for AI Utilities Factory (aiutils_hs.dll): 0xEC55106C (was 0x10281865 = 271063141) * new UID for MenuInterface_hs.dll: 0xEEE24485 (was 0x10210EAB = 270601899) * new UID for XCFW_hs.dll: 0xEB12332F (was 0x10210EA0 = 270601888) * new UID for ailaunch_hs.exe: 0xEF5A047A (was 0x200286E3 = 537036515)

/*
* 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:  Flyweigth pattern implementation for dom strings.
*
*/

#ifndef XN_DOM_STRING_POOL_H
#define XN_DOM_STRING_POOL_H

//  INCLUDES
#include <e32base.h>
#include <s32strm.h>
#include "xndomstringpooloptimizer.h"

// CLASS DECLARATION

/**
*  @ingroup group_domdocument
*  Class utilize flyweight pattern. Dom strings are stored once 
*  and referred with index. Class can be serialized.
*
*  @lib xndomdocument.lib
*  @since Series 60 3.1
*/
class CXnDomStringPool : public CBase
    {
    public:  // Constructors and destructor
        
        /**
        * Two-phased constructor.
        * 
        * @param    aAllowDuplicates        ETrue if duplicates are to be allowed.
        *                                   Supported for legacy reasons. 
        */
        static CXnDomStringPool* NewL( const TBool aAllowDuplicates = EFalse );

        /**
        * Two-phased stream constructor.
        * 
        * @param    aStream                 Stream where string pool is internalized.
        * @param    aAllowDuplicates        ETrue if duplicates are to be allowed.
        *                                   Supported for legacy reasons. 
        */
        static CXnDomStringPool* NewL( RReadStream& aStream,
                const TBool aAllowDuplicates = EFalse );
        
        /**
        * Destructor.
        */
        virtual ~CXnDomStringPool();
        
   public: 
        /**
        * Make a copy from original StringPool.
        * @since Series 60 3.1
        * @return Pointer to a string pool. Ownership is transferred to a caller.
        */
        CXnDomStringPool* CloneL(); 
        
   public: //Adding
        
        /**
        * Set dom string into string pool.
        * 
        * @param aString String to add to string pool
        * @return Index (reference) to string pool
        */
        TInt AddStringL( const TDesC8& aString ); 

        /**
        * Set dom string into string pool.
        * 
        * @param aString String to add to string pool. OWNERSHIP TRANSFERRED!
        * @return Index (reference) to string pool
        */
        TInt AddStringL( HBufC8* aString );         

        /**
        * Add all string from another string pool.
        * 
        * @param aStringPool    Source string pool.
        */
        void AddAllL( CXnDomStringPool& aStringPool );        
        
   public: //Accessing     
        /**
        * Get reference to string.
        * 
        * @param aMap Map object which has index to name string
        * @return Pointer to the name
        */
        const TDesC8& String( const TInt aStringRef ); 
        
        /**
        * Get object's data size in bytes.
        * 
        * @return Data size in bytes
        */
        TInt Size() const;

        /**
        * Get amount of strings.
        */
        TInt Count() const;        
        
        /**
        * Externalize object.
        * 
        * @param aStream Output stream
        */
        void ExternalizeL( RWriteStream& aStream ) const;
       
        /**
        * Internalize object.
        * 
        * @param aStream Input stream
        */
        void InternalizeL( RReadStream& aStream );          
        
   private:

        /**
        * C++ default constructor.
        * 
        * @param    aAllowDuplicates        ETrue if duplicates are to be allowed.
        *                                   Supported for legacy reasons.
        */
        CXnDomStringPool( const TBool aAllowDuplicates );

        /**
        * By default Symbian 2nd phase constructor is private. 
        */
        void ConstructL();    
        
        /**
        * Add string to string pool and to optimizer also.
        * 
        * @param aNewString     String to be added. OWNERSHIP TRANSFERRED.
        * @param TInt           Index to added string.
        */
        TInt DoAddStringL( HBufC8* aNewString ) ;
        
    private:            
        //String pool
        RPointerArray<HBufC8>       iStringPool;
        
        /**
         * String pool optimizer.
         */
        TXnDomStringPoolOptimizer iStringPoolOptimizer;
        
        /**
         * ETrue if string pool can contain duplicate entries. Must
         * be supported for legacy reasons while loading xuikon odts.
         */
        TBool iAllowDuplicates;
    };

#endif      // XN_DOM_STRING_POOL_H  
            
// End of File