xcfw/inc/xcfwlocalizer.h
changeset 0 79c6a41cd166
child 54 666a2952b5b3
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/xcfw/inc/xcfwlocalizer.h	Thu Dec 17 08:54:17 2009 +0200
@@ -0,0 +1,131 @@
+/*
+* Copyright (c) 2002-2005 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:  Class definition of XCFW DTD handler responsible for 
+*                entity conversions (localization)
+*
+*/
+
+
+
+#ifndef CXCFWLOCALIZER_H
+#define CXCFWLOCALIZER_H
+
+//  INCLUDES
+#include <s32std.h>
+#include <badesca.h>
+//#include <gmxmlentityconverter.h>
+//#include <gmxmlcomposer.h>
+
+// FORWARD DECLARATIONS
+class RFileReadStream;
+class RFs;
+
+/**
+* Localization handling class. Responsible for holding entity references 
+* and their corresponding text values loaded from a DTD file. Used for content 
+* localization purposes in XCFW.
+*
+*  @lib XCFW.lib
+*  @since Series 60 3.1
+*/
+class CXCFWLocalizer :  public CBase //CMDXMLEntityConverter
+    {
+    public:  // Constructors and destructor
+        
+        /**
+        * Two-phased constructor.
+        * @param aData Node data object
+        */
+        static CXCFWLocalizer* NewL();
+
+        /**
+        * Destructor.
+        */
+        virtual ~CXCFWLocalizer();
+
+    public: // New functions
+        
+        /**
+        * Loads Entity references from DTD file
+        * @since Series 60 3.1
+        * @param aDTD File to load
+        * @param aFs File system handle to use
+        * @param aStatus Engine's request status, which Localizer will
+        *   complete when DTD parsing is ready
+        */
+        void LoadDTDL(const TDesC& aDTD, 
+            RFs& aFileSystem, 
+            TRequestStatus* aStatus );
+        
+        /**
+        * Converts a XML entity reference to localized text
+        * @since Series 60 3.1
+        * @param aRef Entity reference to convert
+        * @param aText Localized text returned
+        * @return Error code, e.g. KErrNotFound if given entity reference
+        *  is not found.
+        */
+        TInt EntityRefToText(TDesC& aRef, TPtrC& aText);
+        
+        /** 
+        * Converts given localized text into an entity reference
+        * @s
+        ince Series 60 3.1
+        * @param aText text to get entity reference for
+        * @param aRef Entity reference returned
+        * @return Error code, e.g. KErrNotFound if no entity reference
+        *  is found for the given text.
+        */
+        TInt TextToEntityRef(TDesC& aText, TPtrC& aRef);
+        
+        /**
+        * Returns error code from the last LoadDTDL operation
+        * Engine uses this to check that operation was successful when
+        * Localizer completes the pending request.
+        * @since Series 60 3.1
+        * @return Error code from latest DTD load operation
+        */
+        TInt LastError();
+
+    private:
+
+        /**
+        * C++ default constructor.
+        */
+        CXCFWLocalizer();
+
+        /**
+        * By default Symbian 2nd phase constructor is private.
+        */
+        void ConstructL();
+
+        /**
+        * DTD file parsing facility
+        * @param aStream file stream to parse
+        * @since Series 60 3.1
+        */
+        void ParseDTDL( RFileReadStream& aStream );
+
+    private:    // Data
+        
+        //Descriptor arrays for entity references and texts
+        CDesCArraySeg*  iReferences; //Own: Entity references without & and ;
+        CDesCArraySeg*  iLocStrings; //Own: Localized texts
+        TRequestStatus* iStatus; //Not owned: 
+                
+    };
+
+#endif      // CXCFWLOCALIZER_H   
+            
+// End of File