idlehomescreen/inc/xndomstringpooloptimizer.h
author jake
Wed, 12 May 2010 13:22:51 +0300
branchRCL_3
changeset 21 45cc9ca502a9
parent 2 08c6ee43b396
permissions -rw-r--r--
Merge bug fix

/*
* 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:  Optimizer module for CXnDomStringPool.
*
*/

#ifndef XN_DOM_STRING_POOL_OPTIMIZER_H
#define XN_DOM_STRING_POOL_OPTIMIZER_H

//  INCLUDES
#include <e32base.h>

// CLASS DECLARATION

/**
*  @ingroup group_domdocument
*  Optimizer module entry for CXnDomStringPool.
*
*  @lib xndomdocument.lib
*  @since Series 60 5.2
*/
class TXnDomStringPoolOptimizerEntry
    {
    public: // Construction.
        /**
         * Constructor.
         * 
         * @param aIndex    Index.
         * @param aString   String.
         */
        TXnDomStringPoolOptimizerEntry( TInt aIndex, const TDesC8& aString ); 

    public: // Data.
        /**
         * Index of string in actual string pool.
         */
        TInt iIndex;
        
        /**
         * Reference to string in string pool.
         */
        const TDesC8& iString;                    
    };        

/**
*  @ingroup group_domdocument
*  Optimizer module for CXnDomStringPool.
*
*  @lib xndomdocument.lib
*  @since Series 60 5.2
*/
class TXnDomStringPoolOptimizer
    {
    public:
        /**
         * Add entry to optimizer list.
         * 
         * @param aEntry    Entry to be added.
         */
        void AddEntryL( TXnDomStringPoolOptimizerEntry& aEntry );
        
        /**
         * Get index for string.
         * 
         * @param   aString     Reference to given string.
         * @return  TInt        Index to actual string pool for string if found.
         *                      If string is not found will return KErrNotFound. 
         */
        TInt GetIndex( const TDesC8& aString );

        /**
         * Reset.
         */
        void Reset();        
        
        /**
         * Close allocated resources.
         */
        void Close();

        /**
         * Get item count.
         */
        TInt Count();        

        /**
         * Get entry.
         * 
         * @param aIndex    Index to Entry.
         */
        TXnDomStringPoolOptimizerEntry& Entry( const TInt aIndex );        
        
    private:
        /**
         * Find entry from alphabetic list.
         * Uses binary search.
         * 
         * @param       aString Reference to string to be searched for.
         * @param       aLeft   Left limit for binary search
         * @param       aRight  Right limit for binary search.
         * 
         * @return      Index to OPTIMIZER ARRAY. KErrNotFound if
         *              given string is not found.
         */
        TInt FindEntry( const TDesC8& aString,
                        const TInt aLeft,
                        const TInt aRight );

        /**
         * Find a position clue for given string.
         * 
         * Will return index that can be used to initiate linear
         * search. Uses binary search to limit required comparisons
         * when string pools starts to fill.
         * 
         * Note: Returned index is not absolute! it must be
         * only used as a start index for linear searching.
         * 
         * Returned index will be quite close to actual insertion position.
         * it will be 0 - 2 steps backward from actual position.
         * 
         * @param       aString Reference to string.
         * @param       aLeft   Left limit for binary search
         * @param       aRight  Right limit for binary search.
         * 
         * @return      Index to start searching for position
         *              for given string.
         */
        TInt FindInsertionIndexEstimate( const TDesC8& aString,
                                         const TInt aLeft,
                                         const TInt aRight );
        
    private: // Data.
        /**
         * Array of optimizer entries.
         */
        RArray<TXnDomStringPoolOptimizerEntry> iEntries;
    }; 

#endif      // XN_DOM_STRING_POOL_OPTIMIZER_H  
            
// End of File