xml/legacyminidomparser/XMLParser/INC/GMXMLEntityConverter.h
changeset 0 e35f40988205
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/xml/legacyminidomparser/XMLParser/INC/GMXMLEntityConverter.h	Thu Dec 17 09:29:21 2009 +0200
@@ -0,0 +1,91 @@
+// 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