// Copyright (c) 2001-2009 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:
//
/**
 @file
*/
#ifndef __GMXMLENTITYCONVERTER_H__
#define __GMXMLENTITYCONVERTER_H__
#include <e32std.h>
#include <txtetext.h>
class CMDXMLEntityConverter: public CBase
/**
 * This class represents a generic entity converter for an XML parser or composer.
 * It is responsible for converting entity references to text and vice-versa.
 * @publishedPartner
 * @released
 */
	{
public:
	/**
	 * Constructor
	 */
	IMPORT_C CMDXMLEntityConverter();
	/** Destructor. */
	IMPORT_C virtual ~CMDXMLEntityConverter();
	/**
	 * Takes a block of text and converts any entity references found to the
	 * appropriate text.  Because built-in and character entity references are
	 * longer than the replacement text, this takes place in-situ.
	 * @param aTextToConvert Text to be converted - replacement text goes
	 * out in the same
	 * @return Returns KErrNone if successful or no entity found
	 * @return Returns KErrXMLBadEntity if malformed entity found
	 */
	TInt EntityToTextL(TDes& aTextToConvert);
	/**
	 * Outputs a block of text to a composer with offending characters replaced by
	 * entity references.
	 * @param aComposer the composer to be used for output
	 * @param aTextToConvert The text to be converted.
	 * @return Returns KErrNone if succcessful or a file write error
	 * @leave can Leave due to OOM
	 */
	IMPORT_C virtual TInt OutputComposedTextL( CMDXMLComposer* aComposer, const TDesC& aTextToConvert );
protected:
	/**
	 * DTD Specific entity to text converter
	 * Takes a block of text and converts any entity references found to the
	 * appropriate text.  We hope that this can happen in-situ.
	 * @param aTextToConvert Text to be converted - replacement text goes
	 * out in the same
	 * @return Returns KErrNone if successful or no entity found
	 * @return Returns KErrXMLBadEntity if malformed entity found
	 */
	virtual TInt DTDEntityToText(TDes& aTextToConvert);
private:
	/**
	 * Replaces the built in entity reference with its replacement text.
	 * @param aTextToConvert An entity reference to convert.  This should begin with &
	 * and end with ;.
	 * @return Returns KErrNone if successful
	 * @return Returns KErrUnsupported if aTextToConvert contains no recognised entity references
	 * @return Returns KErrOverflow or KErrGeneral if the character reference couldn't be parsed
	 */
	TInt ConvertEntityRefL(TDes& aTextToConvert);
	};
#endif