libraries/ltkutils/src/bsymtree.h
author Tom Sutcliffe <thomas.sutcliffe@accenture.com>
Tue, 07 Sep 2010 20:04:42 +0100
changeset 63 ea6622dea85a
parent 0 7f656887cf89
permissions -rw-r--r--
Build fixes for bmarm, terminal keyboard on TB9.2, gcc 2.9

// bsymtree.h
// 
// Copyright (c) 2010 Accenture. All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the "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:
// Accenture - Initial contribution
//
#ifndef FSHELL_BSYMTREE_H
#define FSHELL_BSYMTREE_H

#include <e32std.h>
class CDesC16Array;

namespace LtkUtils
	{
	class RLtkBuf16;

	class RNode
		{
	public:
		static RNode* NewL();
		void InsertStringL(const TUint16* aString, TInt aValue=0);
		~RNode();
		void CompleteL(TDes& aPrefix, CDesC16Array& aResults);
		TInt ValueForStringL(const TDesC& aString) const;

	private:
		RNode* ChildForLetter(char aChild) const;
		RNode* AddChildL(char aChild);
		RNode(char aLetter);
		RNode* Sprog() const;
		RArray<RNode*>& Sprogs() const;
		RNode* WalkToEndOfString(TUint16*& aString);
		RNode* TabFill(TUint16*& aString, const TUint16* aEnd);
		void DoCompleteOptionsL(CDesC16Array& aResults, RLtkBuf16& aCurrent);
		//void Dump() const; // Debug

	private:
		char iLetter;
		char iHasChildArray;
		short iPad;
		TAny* iPtr; // Either an RNode* or an RArray<RNode*>*. Or a TInt for the value if (iLetter == 0 && !iHasChildArray)
		};

	}

#endif