diff -r 5315654608de -r 08c6ee43b396 idlehomescreen/inc/xndomstringpooloptimizer.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/idlehomescreen/inc/xndomstringpooloptimizer.h Mon Jan 18 20:10:36 2010 +0200 @@ -0,0 +1,153 @@ +/* +* 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 + +// 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 iEntries; + }; + +#endif // XN_DOM_STRING_POOL_OPTIMIZER_H + +// End of File