xcfw/inc/xcfwlocalizer.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 08:54:17 +0200
changeset 0 79c6a41cd166
permissions -rw-r--r--
Revision: 200949 Kit: 200951

/*
* 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